我将使用Python的ElementTree文档here中的示例:
<?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()
功能只按标签名称搜索,即“国家/地区”,“排名”等。我知道我可以循环浏览所有国家/地区标签,看看他们的名称属性是否与新加坡匹配,但我想知道是否有使用我缺少的内置函数的更快方法。
答案 0 :(得分:3)
使用XPath表达式(如正则表达式,但对于XML)
类似于上面的例子:
# Nodes with name='Singapore' that have a 'year' child
root.findall(".//year/..[@name='Singapore']")