I am trying to extract the first and third columns of this data table using BeautifulSoup. From looking at the HTML the first column has a <th> tag. The other column of interest has as <td> tag. In any case, all I’ve been able to get out is a list of the column with the tags. But, I just want the text.
table is already a list so I can’t use findAll(text=True). I’m not sure how to get the listing of the first column in another form.
from BeautifulSoup import BeautifulSoup
from sys import argv
import re
filename = argv[1] #get HTML file as a string
html_doc = ''.join(open(filename,'r').readlines())
soup = BeautifulSoup(html_doc)
table = soup.findAll('table')[0].tbody.th.findAll('th') #The relevant table is the first one
print table
You can try this code:
As you can see the code just connects to the url and gets the html, and the BeautifulSoup finds the first table, then all the ‘tr’ and selects the first column, which is the ‘th’, and the third column, which is a ‘td’.