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


当前回答

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

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

其他回答

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

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

您可以使用lxml中的简单soupparser

例子:

from lxml.html.soupparser import fromstring

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

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

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

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

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