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


当前回答

你可以使用:

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

其他回答

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

另一个选项是py-dom-xpath,它与minidom无缝合作,是纯Python,所以可以在appengine上工作。

import xpath
xpath.find('//item', doc)

听起来像是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

您可以使用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