我使用Python2.7、lxml3.7.3和exlst扩展通过XPath从XML中提取数据。我可以在测试节点时使用正则表达式扩展,就像lxml documentation 建议的那样。摘录:
>>> regexpNS = "http://exslt.org/regular-expressions"
>>> find = etree.XPath("//*[re:test(., '^abc$', 'i')]",
... namespaces={'re':regexpNS})
>>> root = etree.XML("<root><a>aB</a><b>aBc</b></root>")
>>> print(find(root)[0].text)
aBc我想使用xpath表达式只生成节点text()的子字符串。我该怎么做?
发布于 2017-10-26 14:36:44
要在这里使用xpath表达式,可以这样做
import xml.etree.ElementTree as ET
root = ET.fromstring("<root><a>aB</a><b>aBc</b></root>")
for item in root.findall(".//b"):
print(item.text)
# aBc有关更多示例,请参阅他们的。
https://stackoverflow.com/questions/46947246
复制相似问题