我是这个领域的新手,所以我敢肯定这很明显。我正在尝试更改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标记。
实际上,我想搜索标记的组合,因此我排列了一个更复杂的表达式,但我无法使用简单的表达式!
答案 0 :(得分:2)
问题的代码在使用Python 3.7时有效。如果删除谓词中等号前后的空格,则它也适用于早期的Python版本。
Py_Initialize();
worldb.publicnumber = 1;
bp::object main_module = bp::import("__main__");
bp::object main_namespace = main_module.attr("__dict__");
main_namespace["Worldb"] = bp::class_<Worldb>("Worldb")
.def("messagewindow", &Worldb::messagewindow)
.def("setnumber", &Worldb::setnumber)
.def("getnumber", &Worldb::getnumber);
main_namespace["cpp"] = bp::ptr(&worldb);//to prevent the worldb object copied
bp::object compileit;
try
{
compileit = exec(
"cpp.messagewindow(cpp.getnumber())\n"
"cpp.setnumber(8)\n",
main_namespace);
}
catch(bp::error_already_set &)