python - 使用 Python 从 xml 文件中获取元素值
问题描述
我需要使用 Python 从 .xml 文件中提取/修改元素。为此,我正在使用 xml.etree.ElementTree 但我没有从我的代码中获得所需的输出。我需要从 .xml 文件中提取元素“地址”(在本例中为 10.25.0.0):
<?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 subnet in root.iter('address'):
print (subnet)
在代码中我没有得到任何错误也没有值(10.25.0.0 根据需要)。有人可以给我一个想法吗?
解决方案
我知道这可能不是你所期望的,但你总是可以这样尝试:
with open('csr1kv_file.xml') as f:
address = str(f.read()).split("<address>")[1].split("</address>")[0]
编辑:我在这里回答,评论部分很难处理
如果你想用别的东西改变 <address> 的值,你可以尝试:
with open('csr1kv_file.xml') as f:
address = str(f.read()).split("<address>")[1].split("</address>")[0]
f_update = str(f.read()).replace("<address>" + str(address) + "</address>", "<address> whatever_address_you_want </address>")
with open('csr1kv_file.xml', 'w') as f2:
f2.write(f_update)
编辑编号 2: 使用您提供的示例数据,这个在我的机器上正常工作:
with open('csr1kv_file.xml') as f:
full = f.read()
address = str(full).split("<address>")[1].split("</address>")[0]
f.close()
f_update = str(full).replace("<address>" + str(address) + "</address>","<address>whatever_ip</address>")
with open('csr1kv_file.xml', 'w') as f2:
f2.write(f_update)
f2.close()
推荐阅读
- c - C 中的运算符优先级,摄氏度到华氏度
- php - Laravel 注销特定用户
- asp.net-mvc - 如何在 ASP.net MVC 中获取最终的网页标题?
- java - 如何使用 Java 8 时间 API 将两位数年份转换为全年
- reactjs - 反应路由器更改道具时如何以及在何处调度动作
- django - 我将如何在管理员 change_list_result.html 中获取模型名称
- java - “中止:没有提供 EMF 资源的路径!”
- ios - 在 Windows 中从命令提示符运行 xctestrun
- jenkins - 拆分詹金斯变量并触发多个作业
- artifactory - Artifactory 是否支持嵌入式 Derby 数据库的 HA 模式?