支持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)
推荐文章
- 将Pandas或Numpy Nan替换为None以用于MysqlDB
- 使用pandas对同一列进行多个聚合
- 使用Python解析HTML
- django MultiValueDictKeyError错误,我如何处理它
- 如何在for循环期间修改列表条目?
- 我如何在Django中创建一个鼻涕虫?
- 没有名为'django.core.urlresolvers'的模块
- 蟒蛇导出环境文件
- Django - makemigrations -未检测到任何更改
- SQLAlchemy:引擎、连接和会话差异
- 在Python Pandas中删除多个列中的所有重复行
- 更改pandas DataFrame中的特定列名
- 将Pandas多索引转换为列
- 熊猫在每组中获得最高的n个记录
- 熊猫数据帧得到每组的第一行