使用 Python 2 在 XML 中按属性查找所有节点

Find all nodes by attribute in XML using Python 2(使用 Python 2 在 XML 中按属性查找所有节点)
本文介绍了使用 Python 2 在 XML 中按属性查找所有节点的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

我有一个 XML 文件,其中包含许多具有相同属性的不同节点.

I have an XML file which has a lot of different nodes with the same attribute.

我想知道是否可以使用 Python 和任何其他包(如 minidom 或 ElementTree)找到所有这些节点.

I was wondering if it's possible to find all these nodes using Python and any additional package like minidom or ElementTree.

推荐答案

可以使用内置的xml.etree.ElementTree 模块.

You can use built-in xml.etree.ElementTree module.

如果您希望所有元素都具有特定属性而不考虑属性值,则可以使用 xpath 表达式:

If you want all elements that have a particular attribute regardless of the attribute values, you can use an xpath expression:

//tag[@attr]

或者,如果您关心价值观:

Or, if you care about values:

//tag[@attr="value"]

示例(使用 <代码>findall() 方法):

Example (using findall() method):

import xml.etree.ElementTree as ET

data = """
<parent>
    <child attr="test">1</child>
    <child attr="something else">2</child>
    <child other_attr="other">3</child>
    <child>4</child>
    <child attr="test">5</child>
</parent>
"""

parent = ET.fromstring(data)
print [child.text for child in parent.findall('.//child[@attr]')]
print [child.text for child in parent.findall('.//child[@attr="test"]')]

打印:

['1', '2', '5']
['1', '5']

这篇关于使用 Python 2 在 XML 中按属性查找所有节点的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

相关文档推荐

groupby multiple coords along a single dimension in xarray(在xarray中按单个维度的多个坐标分组)
Group by and Sum in Pandas without losing columns(Pandas中的GROUP BY AND SUM不丢失列)
Group by + New Column + Grab value former row based on conditionals(GROUP BY+新列+基于条件的前一行抓取值)
Groupby and interpolate in Pandas(PANDA中的Groupby算法和插值算法)
Pandas - Group Rows based on a column and replace NaN with non-null values(PANAS-基于列对行进行分组,并将NaN替换为非空值)
Grouping pandas DataFrame by 10 minute intervals(按10分钟间隔对 pandas 数据帧进行分组)