支持XPath的库有哪些?是否有完整的实现?图书馆是如何使用的?它的网站在哪里?
当前回答
elementtree的最新版本很好地支持XPath。我不是XPath专家,不能肯定实现是否完整,但它满足了我在Python中工作时的大部分需求。我也使用过lxml和PyXML,我发现etree很好,因为它是一个标准模块。
注意:我已经找到了lxml,对我来说,它绝对是Python中最好的XML库。它也很好地使用了XPath(尽管可能不是一个完整的实现)。
其他回答
您可以使用lxml中的简单soupparser
例子:
from lxml.html.soupparser import fromstring
tree = fromstring("<a>Find me!</a>")
print tree.xpath("//a/text()")
你可以使用:
PyXML:
from xml.dom.ext.reader import Sax2
from xml import xpath
doc = Sax2.FromXmlFile('foo.xml').documentElement
for url in xpath.Evaluate('//@Url', doc):
print url.value
libxml2:
import libxml2
doc = libxml2.parseFile('foo.xml')
for url in doc.xpathEval('//@Url'):
print url.content
如果你想拥有XPATH的强大功能,同时还能在任何时候使用CSS,你可以使用parsel:
>>> from parsel import Selector
>>> sel = Selector(text=u"""<html>
<body>
<h1>Hello, Parsel!</h1>
<ul>
<li><a href="http://example.com">Link 1</a></li>
<li><a href="http://scrapy.org">Link 2</a></li>
</ul
</body>
</html>""")
>>>
>>> sel.css('h1::text').extract_first()
'Hello, Parsel!'
>>> sel.xpath('//h1/text()').extract_first()
'Hello, Parsel!'
lxml包支持xpath。它似乎工作得很好,尽管我在使用self::轴时遇到了一些麻烦。还有阿玛拉,但我个人没用过。
听起来像是lxml的广告。,)ElementTree包含在std库中。在2.6及以下,它的xpath相当弱,但在2.7+和3。X大大提高:
import xml.etree.ElementTree as ET
root = ET.parse(filename)
result = ''
for elem in root.findall('.//child/grandchild'):
# How to make decisions based on attributes:
if elem.attrib.get('name') == 'foo':
result = elem.text
break
推荐文章
- 证书验证失败:无法获得本地颁发者证书
- 当使用pip3安装包时,“Python中的ssl模块不可用”
- 无法切换Python与pyenv
- Python if not == vs if !=
- 如何从scikit-learn决策树中提取决策规则?
- 为什么在Mac OS X v10.9 (Mavericks)的终端中apt-get功能不起作用?
- 将旋转的xtick标签与各自的xtick对齐
- 为什么元组可以包含可变项?
- 如何合并字典的字典?
- 如何创建类属性?
- 不区分大小写的“in”
- 在Python中获取迭代器中的元素个数
- 解析日期字符串并更改格式
- 使用try和。Python中的if
- 如何在Python中获得所有直接子目录