python读写xml文件实例详解嘛

 更新时间:2022年03月03日 09:11:20   作者:单单一个越字  
这篇文章主要为大家详细介绍了python读写xml文件的实例,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助

xml文件:country.xml

<data>
	<country name="shdi2hajk">231
		<rank>1<NewNode A="1">This is NEW</NewNode></rank>
		<year>2008</year>
		<gdppc>141100</gdppc>
		<neighbor direction="E" name="Austria" />  
		<neighbor direction="W" name="Switzerland" />
	</country>
	<country name="Singapore">
		<rank>4</rank>
		<year>2011</year>
		<gdppc>59900</gdppc>
		<neighbor direction="N" name="Malaysia" />
	</country>
	<country name="Panama">
		<rank>68</rank>
		<year>2011</year>
		<gdppc>13600</gdppc>
		<neighbor direction="W" name="Costa Rica" />
		<neighbor direction="E" name="Colombia" />
	</country>
	<MediaPlatformService height="165" ip="36.32.160.199" passWord="111" port="9084" userName="admin" width="220">
	</MediaPlatformService>
</data>

xml文件解读

1.xml一个节点有三个属性:tag、text、attrib
2. 以第一个子节点country为例:
3. tag代表节点名字,country节点的tag就是它的名字:country
4. text代表节点文本内容,rank节点的text就是1
5. attrib代表节点包含的属性,以{属性:值}这样的字典形式存放。country节点的属性是{name:Liechtenstein}.name是属性的键,Liechtenstein是属性的值。{属性:值}就是一个字典类型,可以使用一切字典方法。
6. country节点的tag为country,attrib为{name:Liechtenstein},text为空
7. rank节点的tag为rank,attrib为空字典,text为1
8. 综上所述,xml文档主要由节点以及节点的三个属性组成。

读取文件:

import xml.etree.ElementTree as ET
file_path = r'xml_te.xml'
tree = ET.ElementTree(file = file_path)  #读取xml文件
print(tree.iter())
for i in tree.iter('rank'):  #迭代获取tag为'rank'的节点
    print(i.text)
nodes = tree.find('country') #获取第一个tag为country的节点,返回是子节点的迭代对象
print(nodes.tag)
nodes2 = tree.findall('country') #获取所有tag为country的节点
print(nodes2)
for node in nodes2:
    #打印节点的三个属性
    print(node.tag)
    print(node.attrib)
    print(node.text)

增加新节点及修改属性值和文本

import xml.etree.ElementTree as ET
file_path = r'xml_te.xml'
tree = ET.ElementTree(file = file_path)  #读取xml文件

# root = tree.getroot()  #获取根结点
"""增加新节点"""
net = ET.Element('NewNode')
net.attrib = {'A':"1"}   #节点属性
net.text = "This is NEW"   #节点文本
node = tree.find('country/rank/NewNode')   #找到需要增加子节点的父节点
node.append(net)
print(node.text)
tree.write(file_path)  #写入文件
"""修改属性值"""
sub = tree.find('country')   #找到节点
sub.set('name',"shdi2hajk")  #set(key,new value)
sub.text = '231'
print(sub.attrib)
print(sub.text)
tree.write(file_path)  #写入文件

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注脚本之家的更多内容! 

相关文章

  • Python模拟三级菜单效果

    Python模拟三级菜单效果

    这篇文章主要为大家详细介绍了Python模拟三级菜单效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-09-09
  • Django项目连接MongoDB的三种方法

    Django项目连接MongoDB的三种方法

    本文主要介绍了Django项目连接MongoDB的三种方法,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • python sys模块使用方法介绍

    python sys模块使用方法介绍

    sys模块是最常用的和python解释器交互的模块,sys模块可供访问由解释器(interpreter)使用或维护的变量和与解释器进行交互的函数,需要的朋友可以参考下
    2022-08-08
  • pycharm使用sftp同步服务器的步骤

    pycharm使用sftp同步服务器的步骤

    这篇文章主要介绍了pycharm使用sftp同步服务器,其实完全可以结合frp进行内网穿透,本文分步骤给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03
  • python如何从文件读取数据及解析

    python如何从文件读取数据及解析

    这篇文章主要介绍了python如何从文件读取数据,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-09-09
  • python开发游戏的前期准备

    python开发游戏的前期准备

    在本篇文章中我们给大家分享了关于python开发游戏的前期准备以及用到的工具等内容,需要的朋友们跟着参考下。
    2019-05-05
  • Python实现的最近最少使用算法

    Python实现的最近最少使用算法

    这篇文章主要介绍了Python实现的最近最少使用算法,涉及节点、时间、流程控制等相关技巧,需要的朋友可以参考下
    2015-07-07
  • 浅谈Python中的作用域规则和闭包

    浅谈Python中的作用域规则和闭包

    本文简单讲解了PYTHON的闭包,作用域的基本知识配合实例简单明了,适合初学者
    2018-03-03
  • 使用Python自定义创建的Log日志模块

    使用Python自定义创建的Log日志模块

    这篇文章主要介绍了使用Python自定义创建的Log日志模块,日志文件是用于记录系统操作事件的文件集合,可分为事件日志和消息日志。具有处理历史数据、诊断问题的追踪以及理解系统的活动等重要作用,需要的朋友可以参考下
    2023-07-07
  • python pandas轻松通过特定列的值多条件去筛选数据及contains方法的使用

    python pandas轻松通过特定列的值多条件去筛选数据及contains方法的使用

    这篇文章主要介绍了python pandas轻松通过特定列的值多条件去筛选数据及contains方法的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-02-02

最新评论