我有一个 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 中按属性查找所有节点的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!
使用 python 解析非常大的 xml 文件时出现问题Troubles while parsing with python very large xml file(使用 python 解析非常大的 xml 文件时出现问题)
Python - 如何解析 xml 响应并将元素值存储在变量中Python - How to parse xml response and store a elements value in a variable?(Python - 如何解析 xml 响应并将元素值存储在变量中?)
如何在 Python 中获取 XML 标记值How to get XML tag value in Python(如何在 Python 中获取 XML 标记值)
如何使用 ElementTree 正确解析 utf-8 xml?How to correctly parse utf-8 xml with ElementTree?(如何使用 ElementTree 正确解析 utf-8 xml?)
将 XML 从 URL 解析为 python 对象Parse XML from URL into python object(将 XML 从 URL 解析为 python 对象)
Python 中的大型 XML 文件解析Large XML File Parsing in Python(Python 中的大型 XML 文件解析)