支持XPath的库有哪些?是否有完整的实现?图书馆是如何使用的?它的网站在哪里?


当前回答

lxml包支持xpath。它似乎工作得很好,尽管我在使用self::轴时遇到了一些麻烦。还有阿玛拉,但我个人没用过。

其他回答

你可以使用:

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

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()")

lxml包支持xpath。它似乎工作得很好,尽管我在使用self::轴时遇到了一些麻烦。还有阿玛拉,但我个人没用过。

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蟒蛇。基本的文档都在这里。