支持XPath的库有哪些?是否有完整的实现?图书馆是如何使用的?它的网站在哪里?
当前回答
另一个库是4Suite: http://sourceforge.net/projects/foursuite/
我不知道它是否符合规格。但它对我的使用非常有效。它看起来被遗弃了。
其他回答
另一个选项是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
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()")
你可以使用:
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
推荐文章
- 证书验证失败:无法获得本地颁发者证书
- 当使用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中获得所有直接子目录