Python - lxml /获取xpath的完整内容

时间:2013-08-21 04:37:44

标签: python xpath lxml

例如,使用Twitter,此代码从Twitter页面中删除第5条推文。该页面包含一个链接,除非我尝试使用lxml和xpath将其拉出时,它只显示截断末尾链接的文本。

脚本:

import urllib2
from lxml import etree

xpathselector = "/html/body/div/div[2]/div/div[5]/div[2]/div/ol/li[5]/div/div/p"
url =  "https://twitter.com/memphismayfire"
response = urllib2.urlopen(url)
htmlparser = etree.HTMLParser()
tree = etree.parse(response, htmlparser)
result = tree.xpath(xpathselector)

print result[0].text

打印

   Aways'Acoustic在iTunes上可用!谁下载了单曲?!让我们把它归结为单曲榜!链接:

来自xPath的HTML位置:

<p class="js-tweet-text tweet-text">'Miles Away' Acoustic is available on iTunes! Who's downloaded the single?! Let's get it up the Singles Chart!! Link: <a title="http://smarturl.it/mmf-miles-away" target="_blank" class="twitter-timeline-link" data-expanded-url="http://smarturl.it/mmf-miles-away" dir="ltr" rel="nofollow" href="http://t.co/fU2hVqAiSq" f52ae163cfcf0237f="true"><span class="tco-ellipsis"></span><span class="invisible">http://</span><span class="js-display-url">smarturl.it/mmf-miles-away</span><span class="invisible"></span><span class="tco-ellipsis"><span class="invisible">&nbsp;</span></span></a><div ida2bb72480="_p_mzkte2cwofawsu3r.t.co" style="cursor: pointer; width: 16px; height: 16px;display: inline-block;">&nbsp;</div></p>

打印xpath的全部内容而不仅仅是文本的最佳方法是什么?谢谢你的帮助!

1 个答案:

答案 0 :(得分:3)

使用lxml.etree.tostring

print etree.tostring(result[0])