使用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标记.

实际上,我想搜索标记的组合,因此我排列了一个更复杂的表达式,但我无法使用简单的表达式!

最佳答案
使用Python 3.7时,问题中的代码有效.如果删除谓词中等号前后的空格,则它也适用于早期的Python版本.

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

参见https://bugs.python.org/issue31648.

相关文章

在这篇文章中,我们深入学习了XPath作为一种常见的网络爬虫技巧。XPath是一种用于定位和选择XML文档中特...
祝福大家龙年快乐!愿你们的生活像龙一样充满力量和勇气,愿你们在新的一年里,追逐梦想,勇往直前,不...
今天在爬虫实战中,除了正常爬取网页数据外,我们还添加了一个下载功能,主要任务是爬取小说并将其下载...
完美收官,本文是爬虫实战的最后一章了,所以尽管本文着重呈现爬虫实战,但其中有一大部分内容专注于数...
JSON是一种流行的数据传输格式,Python中有多种处理JSON的方式。官方的json库是最常用的,它提供了简单...
独立样本T检验适用于比较两组独立样本的均值差异,而配对T检验则适用于比较同一组样本在不同条件下的均...