我有一个像这样的html表:
<TABLE>
<TR>
<TD><P>Name</P></TD>
<TD><P>Fees</P></TD>
<TD><P>Awards</P></TD>
<TD><P>Total</P></TD>
</TR>
<TR>
<TD><P>Tony</P></TD>
<TD >7,800</TD>
<TD >7</TD>
<TD>15,400</TD>
</TR>
<TR>
<TD><P>Paul</FONT></P></TD>
<TD >7,800</TD>
<TD >7</TD>
<TD>15,400</TD>
</TR>
<TR>
<TD><P>Richard</P></TD>
<TD >7,800</TD>
<TD >7</TD>
<TD>15,400</TD>
</TR>
</TR>
</TABLE>
我想提取表的值。我尝试了以下内容。
import lxml.html
html = lxml.html.parse(''html_table)
text_value = html.xpath('//tr/td/text()')
packages = html.xpath('//tr/td/p')
p_content = [p.text_content() for p in packages]
有没有办法将<p>
文字和<td>
的文字同时提取到一个列表中?
答案 0 :(得分:7)
您可以执行类似
的操作>>> doc = """<TABLE>
... <TR>
... <TD><P>Name</P></TD>
... <TD><P>Fees</P></TD>
... <TD><P>Awards</P></TD>
... <TD><P>Total</P></TD>
... </TR>
... <TR>
... <TD><P>Tony</P></TD>
... <TD >7,800</TD>
... <TD >7</TD>
... <TD>15,400</TD>
... </TR>
... <TR>
... <TD><P>Paul</FONT></P></TD>
... <TD >7,800</TD>
... <TD >7</TD>
... <TD>15,400</TD>
... </TR>
... <TR>
... <TD><P>Richard</P></TD>
... <TD >7,800</TD>
... <TD >7</TD>
... <TD>15,400</TD>
... </TR>
...
... </TR>
... </TABLE>"""
>>> import lxml.html
>>> root = lxml.html.fromstring(doc)
>>> root.xpath('//tr/td//text()')
['Name', 'Fees', 'Awards', 'Total', 'Tony', '7,800', '7', '15,400', 'Paul', '7,800', '7', '15,400', 'Richard', '7,800', '7', '15,400']
>>>
如果文档中有2个表,则可以先在表上循环,然后对每个表上的后代文本节点使用相对 XPath表达式(带前导.
)
>>> doc = """<TABLE>
... <TR>
... <TD><P>Name</P></TD>
... <TD><P>Fees</P></TD>
... <TD><P>Awards</P></TD>
... <TD><P>Total</P></TD>
... </TR>
... <TR>
... <TD><P>Tony</P></TD>
... <TD >7,800</TD>
... <TD >7</TD>
... <TD>15,400</TD>
... </TR>
... <TR>
... <TD><P>Paul</FONT></P></TD>
... <TD >7,800</TD>
... <TD >7</TD>
... <TD>15,400</TD>
... </TR>
... <TR>
... <TD><P>Richard</P></TD>
... <TD >7,800</TD>
... <TD >7</TD>
... <TD>15,400</TD>
... </TR>
...
... </TR>
... </TABLE>
... <TABLE>
... <TR>
... <TD><P>Name</P></TD>
... <TD><P>Fees</P></TD>
... <TD><P>Awards</P></TD>
... <TD><P>Total</P></TD>
... </TR>
... <TR>
... <TD><P>Tony</P></TD>
... <TD >7,800</TD>
... <TD >7</TD>
... <TD>15,400</TD>
... </TR>
... <TR>
... <TD><P>Paul</FONT></P></TD>
... <TD >7,800</TD>
... <TD >7</TD>
... <TD>15,400</TD>
... </TR>
... <TR>
... <TD><P>Richard</P></TD>
... <TD >7,800</TD>
... <TD >7</TD>
... <TD>15,400</TD>
... </TR>
...
... </TR>
... </TABLE>"""
>>> import lxml.html
>>> root = lxml.html.fromstring(doc)
>>> root.xpath('//tr/td//text()')
['Name', 'Fees', 'Awards', 'Total', 'Tony', '7,800', '7', '15,400', 'Paul', '7,800', '7', '15,400', 'Richard', '7,800', '7', '15,400', 'Name', 'Fees', 'Awards', 'Total', 'Tony', '7,800', '7', '15,400', 'Paul', '7,800', '7', '15,400', 'Richard', '7,800', '7', '15,400']
>>> for tbl in root.xpath('//table'):
... elements = tbl.xpath('.//tr/td//text()')
... print elements
...
['Name', 'Fees', 'Awards', 'Total', 'Tony', '7,800', '7', '15,400', 'Paul', '7,800', '7', '15,400', 'Richard', '7,800', '7', '15,400']
['Name', 'Fees', 'Awards', 'Total', 'Tony', '7,800', '7', '15,400', 'Paul', '7,800', '7', '15,400', 'Richard', '7,800', '7', '15,400']
>>>