猿问

使用 ElementTree 查找节点 - 谓词无效

我对这个领域很陌生,所以我相信这只是显而易见的事情。我正在尝试更改一个 python 脚本,以便它以不同的方式找到一个节点,但我收到一个“无效谓词”错误。


import xml.etree.ElementTree as ET


tree = ET.parse("/tmp/failing.xml")

doc = tree.getroot()

thingy = doc.find(".//File/Diag[@id='53']")

print(thingy.attrib)

thingy = doc.find(".//File/Diag[BaseName = 'HTTPHeaders']")

print(thingy.attrib)

那应该两次找到相同的节点,但第二次查找得到错误。这是 XML 的摘录:


<Diag id="53">

            <Formatted>xyz</Formatted>

            <BaseName>HTTPHeaders</BaseName>

            <Column>17</Column>

我希望我没有削减太多。基本上,用“@id”找到它是有效的,但我想搜索那个 BaseName 标签。


实际上,我想搜索标签的组合,所以我排列了一个更复杂的表达式,但我无法让简单的表达式起作用!


浮云间
浏览 259回答 1
1回答

弑天下

问题中的代码在使用 Python 3.7 时有效。如果谓词中等号前后的空格被删除,它也适用于早期的 Python 版本。thingy&nbsp;=&nbsp;doc.find(".//File/Diag[BaseName='HTTPHeaders']")请参阅https://bugs.python.org/issue31648。
随时随地看视频慕课网APP

相关分类

Python
我要回答