我一直在尝试编辑XML中包含多个同名元素内容的特定元素内容,但是设置元素属性所需的"for循环“将始终贯穿整个部分并将其全部更改。
假设这是我的XML:
<SectionA>
<element_content attribute="device_1" type="parameter_1" />
<element_content attribute="device_2" type="parameter_2" />
</SectionA>
我目前使用的代码是ElementTree,当某个部分有不同名称的元素内容时,该代码工作得很好,但是对于这种情况--名称是相同的--它不起作用。它只需将所有内容的属性更改为具有相同的值。
for element in root.iter(section):
print element
element.set(attribute, attribute_value)
如何访问特定的元素内容而只更改该内容?
请记住,我不知道element_content部分中当前的属性,因为我正在动态地将它们添加到用户的请求中。
编辑:多亏了@leovp,我能够解决我的问题,并想出了这个解决方案:
for step in root.findall(section):
last_element = step.find(element_content+'[last()]')
last_element.set(attribute, attribute_value)
这将导致for循环始终更改特定嵌套中的最后一个属性。因为我在动态地添加和编辑行,这使得它改变了我添加的最后一行。
谢谢。
发布于 2017-03-21 01:43:30
您可以使用xml.etree
提供的有限的xml.etree
支持:
>>> from xml.etree import ElementTree
>>> xml_data = """
... <SectionA>
... <element_content attribute="device_1" type="parameter_1" />
... <element_content attribute="device_2" type="parameter_2" />
... </SectionA>
... """.strip()
>>> tree = ElementTree.fromstring(xml_data)
>>> d2 = tree.find('element_content[@attribute="device_2"]')
>>> d2.set('type', 'new_type')
>>> print(ElementTree.tostring(tree).decode('utf-8'))
<SectionA>
<element_content attribute="device_1" type="parameter_1" />
<element_content attribute="device_2" type="new_type" />
</SectionA>
这里最重要的部分是一个XPath表达式,在该表达式中,我们通过其名称和属性值找到一个元素:
d2 = tree.find('element_content[@attribute="device_2"]')
更新:因为所讨论的XML数据是事先不知道的。您可以查询第一个、第二个、.最后这样的元素(索引从1开始):
tree.find('element_content[1]')
tree.find('element_content[2]')
tree.find('element_content[last()]')
但是,由于您无论如何都在迭代元素,所以最简单的解决方案就是检查当前元素的属性:
for element in root.iter(section):
if element.attrib.get('type') == 'parameter_2'):
element.set(attribute, attribute_value)
https://stackoverflow.com/questions/42922906
复制