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


当前回答

您可以使用lxml中的简单soupparser

例子:

from lxml.html.soupparser import fromstring

tree = fromstring("<a>Find me!</a>")
print tree.xpath("//a/text()")

其他回答

如果你想拥有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!'

你可以使用:

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

另一个库是4Suite: http://sourceforge.net/projects/foursuite/

我不知道它是否符合规格。但它对我的使用非常有效。它看起来被遗弃了。

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

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

使用LXML。LXML使用了libxml2和libxslt的全部功能,但将它们包装在更多的“Python”绑定中,而不是这些库的原生Python绑定。因此,它获得了完整的XPath 1.0实现。Native ElemenTree支持有限的XPath子集,尽管它可能已经足够满足您的需求。