支持XPath的库有哪些?是否有完整的实现?图书馆是如何使用的?它的网站在哪里?
当前回答
另一个库是4Suite: http://sourceforge.net/projects/foursuite/
我不知道它是否符合规格。但它对我的使用非常有效。它看起来被遗弃了。
其他回答
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蟒蛇。基本的文档都在这里。
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!'
您可以使用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
推荐文章
- 为什么我得到“'str'对象没有属性'读取'”当尝试使用' json。载入字符串?
- 不区分大小写的列表排序,没有降低结果?
- 排序后的语法(key=lambda:…)
- 在烧瓶中返回HTTP状态代码201
- 使用python创建一个简单的XML文件
- APT命令行界面式的yes/no输入?
- 如何打印出状态栏和百分比?
- 在Python中获取大文件的MD5哈希值
- 在Python格式字符串中%s是什么意思?
- 如何循环通过所有但最后一项的列表?
- python用什么方法避免默认参数为空列表?
- ValueError: numpy。Ndarray大小改变,可能表示二进制不兼容。期望从C头得到88,从PyObject得到80
- Anaconda /conda -安装特定的软件包版本
- 我在哪里调用Keras的BatchNormalization函数?
- 打印测试执行时间并使用py.test锁定缓慢的测试