使用Python从xml文件获取子元素值

我需要使用Python从.xml文件中提取/修改子元素。为此,我使用的是xml.etree.ElementTree,但没有从代码中获得所需的输出。我需要从.xml文件中提取“部署”(在本例中为xyz1000_Test_v1)下的元素“名称”:

<?xml version="1.0" encoding="utf-8"?>
<esc
    xmlns="http://www.test.com/esc/esc">
    <tenants>
        <tenant>
            <name>esc</name>
            <deployments>
                <deployment>
                    <name>xyz1000_Test_v1</name>
                    <networks>
                        <network>
                            <name>tenant_1</name>
                            <admin_state>true</admin_state>
                            <subnet>
                                <name>tenant_1_sub</name>
                                <ipversion>ipv4</ipversion>
                                **<address>10.25.0.0</address>**
                            </subnet>
                        </network>
                        <network> .....

这是我正在使用的代码:

import xml.etree.ElementTree as ET
tree = ET.parse('csr1kv_file.xml')
root = tree.getroot()
ET.register_namespace("","http://www.test.com/esc/esc")

for DeploymentName in root.iter('{http://www.test.com/esc/esc}name'):
    print(DeploymentName.text)
    name.text="New deplaoyment name"

但是,从代码中,我得到了“部署”,“网络”和“子网”下的元素值。如何访问特定元素?预先感谢。

更新:

试图从“网络”元素中获取“名称”,我有这段代码。不幸的是,它没有给我期望的答案:

for network in root.findall('{http://www.test.com/esc/esc}network'):
    name = network.find('name').text
    print(name)
gordon000 回答:使用Python从xml文件获取子元素值

文档中的所有元素都绑定到相同的名称空间,并且network元素不是根的直接子代。

对于findall(),请使用此:

for network in root.findall('.//{http://www.test.com/esc/esc}network'):
    name = network.find('{http://www.test.com/esc/esc}name')

或使用iter()

for network in root.iter('{http://www.test.com/esc/esc}network'):
    name = network.find('{http://www.test.com/esc/esc}name')
    if name is not None:  # Avoid "'NoneType' object has no attribute 'text'"
        name.text= 'new name'
本文链接:https://www.f2er.com/3159198.html

大家都在问