支持XPath的库有哪些?是否有完整的实现?图书馆是如何使用的?它的网站在哪里?
当前回答
PyXML工作得很好。
你没有说你使用的是什么平台,但是如果你使用的是Ubuntu,你可以通过sudo apt-get install python-xml来获得它。我相信其他Linux发行版也有这个功能。
如果在Mac上,xpath已经安装,但不能立即访问。你可以在你的环境中设置PY_USE_XMLPLUS,或者在导入xml.xpath之前使用Python的方式:
if sys.platform.startswith('darwin'):
os.environ['PY_USE_XMLPLUS'] = '1'
在最坏的情况下,您可能不得不自己构建它。这个包不再维护,但仍然构建良好,并适用于现代2。x蟒蛇。基本的文档都在这里。
其他回答
您可以使用lxml中的简单soupparser
例子:
from lxml.html.soupparser import fromstring
tree = fromstring("<a>Find me!</a>")
print tree.xpath("//a/text()")
听起来像是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
另一个选项是py-dom-xpath,它与minidom无缝合作,是纯Python,所以可以在appengine上工作。
import xpath
xpath.find('//item', doc)
Libxml2有很多优点:
符合规范 积极发展,社区参与 速度。这实际上是一个C实现的python包装器。 无处不在。libxml2库非常普遍,因此经过了良好的测试。
缺点包括:
严格遵守规范。像默认名称空间处理这样的事情在其他库中更容易。 使用本机代码。根据应用程序的分布/部署方式,这可能会很麻烦。rpm可以在一定程度上缓解这种痛苦。 手工资源处理。注意下面的示例中对freeDoc()和xpathFreeContext()的调用。这不是很Pythonic。
如果您正在做简单的路径选择,请坚持使用ElementTree (Python 2.5中包含了它)。如果您需要完全符合规范或原始速度,并且能够处理本机代码的分发,那么请使用libxml2。
libxml2 XPath使用示例
import libxml2
doc = libxml2.parseFile("tst.xml")
ctxt = doc.xpathNewContext()
res = ctxt.xpathEval("//*")
if len(res) != 2:
print "xpath query: wrong node set size"
sys.exit(1)
if res[0].name != "doc" or res[1].name != "foo":
print "xpath query: wrong node set value"
sys.exit(1)
doc.freeDoc()
ctxt.xpathFreeContext()
ElementTree XPath使用示例
from elementtree.ElementTree import ElementTree
mydoc = ElementTree(file='tst.xml')
for e in mydoc.findall('/foo/bar'):
print e.get('title').text
另一个库是4Suite: http://sourceforge.net/projects/foursuite/
我不知道它是否符合规格。但它对我的使用非常有效。它看起来被遗弃了。