我将使用从Python的ElementTree文档的例子在这里:
<?xml version="1.0"?>
<data>
<country name="Liechtenstein">
<rank>1</rank>
<year>2008</year>
<gdppc>141100</gdppc>
<neighbor name="Austria" direction="E"/>
<neighbor name="Switzerland" direction="W"/>
</country>
<country name="Singapore">
<rank>4</rank>
<year>2011</year>
<gdppc>59900</gdppc>
<neighbor name="Malaysia" direction="N"/>
</country>
<country name="Panama">
<rank>68</rank>
<year>2011</year>
<gdppc>13600</gdppc>
<neighbor name="Costa Rica" direction="W"/>
<neighbor name="Colombia" direction="E"/>
</country>
</data>
有没有一种方法可以搜索属性并返回与属性匹配的元素?在上面的示例中,我想搜索属性名称为Singapore的元素。该findall()
功能仅按标签名称进行搜索,即“国家”,“等级”等。我知道我可以循环遍历所有国家标签,并查看它们的名称属性是否与新加坡匹配,但我想知道是否有一种更快的方法可以使用内置-在我所缺少的功能中。
使用XPath表达式(类似于正则表达式,但用于XML)
与上面的示例类似:
# Nodes with name='Singapore' that have a 'year' child
root.findall(".//year/..[@name='Singapore']")
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句