XML文件格式实例(一):

<?xml version="1.0" encoding="utf-8"?>
<!-- This is list of customers -->
<collection shelf="New Arrivals">      <movie title="Enemy Behind">            <type>War, Thriller</type>            <format>DVD</format>            <year>2003</year>            <rating>PG</rating>            <stars>10</stars>            <description>Talk about a US-Japan war</description>            </movie>      <movie title="Transformers">            <type>Anime, Science Fiction</type>            <format>DVD</format>            <year>1989</year>            <rating>R</rating>            <stars>8</stars>            <description>A schientific fiction</description>            </movie>      <movie title="Trigun">            <type>Anime, Action</type>            <format>DVD</format>            <episodes>4</episodes>            <rating>PG</rating>            <stars>10</stars>            <description>Vash the Stampede!</description>            </movie>      <movie title="Ishtar">            <type>Comedy</type>            <format>VHS</format>            <rating>PG</rating>            <stars>2</stars>            <description>Viewable boredom</description>            </movie>
</collection>
  1. 目的: (1)读取该xml文件中的数据 (2)添加新数据至该xml文件中 (3)xml文档格式整理,方便查看(换行)
    首先导入需要使用的库:
from xml.dom.minidom import parse
import xml.dom.minidom
import time
from xml.etree import ElementTree

(1)读取/修改该xml文件:

def read_xml(path_name):            #传递xml文件路径# 使用minidom解析器打开 XML 文档DOMTree = xml.dom.minidom.parse(path_name)collection = DOMTree.documentElement #获取文档根元素if collection.hasAttribute("shelf"): #获取根元素中shelf的名称print("Root element : %s" % collection.getAttribute("shelf"))# 获取所有关于movie节点下的标签内容movies = collection.getElementsByTagName("movie")  # 打印每部电影的详细信息ii = 1for movie in movies:   #循环movies所有节点,并读取对应标签中的内容数据 print("*****Movie*** %s **部" % i)if movie.hasAttribute("title"):# 获取title节点的名称print("Title: %s" % movie.getAttribute("title"))try:#获取标签中对应标签名称的内容type = movie.getElementsByTagName('type')[0]print("Type: %s" % type.childNodes[0].data)format = movie.getElementsByTagName('format')[0]print ("Format: %s" % format.childNodes[0].data)#修改标签中的内容格式如下:即重新赋值即可,后续标签皆如此写法# format.childNodes[0].data = "textt"rating = movie.getElementsByTagName('rating')[0]print("Rating: %s" % rating.childNodes[0].data)#修改标签中的内容格式如下:即重新赋值即可,后续标签皆如此写法# rating.childNodes[0].data = "textt"stars = movie.getElementsByTagName("stars")[0]print("stars: %s" % stars.childNodes[0].data)description = movie.getElementsByTagName('description')[0]print("Description: %s" % description.childNodes[0].data)i += 1except:pass

(2)添加新数据至该xml文件中:

#XML文档中添加数据
def write_xml():path = "./一/example_2.xml"domTree = parse(path)# 文档根元素rootNode = domTree.documentElement# 新建一个customer节点customer_node = domTree.createElement("movie")customer_node.setAttribute("title", "fuchouzhe")# 创建name节点,并设置textValuename_node = domTree.createElement("type")print(name_node)name_text_value = domTree.createTextNode("kavin")name_node.appendChild(name_text_value)  # 把文本节点挂到name_node节点customer_node.appendChild(name_node)# 创建phone节点,并设置textValuephone_node = domTree.createElement("format")phone_text_value = domTree.createTextNode("32467")phone_node.appendChild(phone_text_value)  # 把文本节点挂到name_node节点customer_node.appendChild(phone_node)# 创建comments节点,这里是CDATAcomments_node = domTree.createElement("stars")cdata_text_value = domTree.createTextNode("ssssss")comments_node.appendChild(cdata_text_value)customer_node.appendChild(comments_node)rootNode.appendChild(customer_node)with open(path, 'w+') as f:# 缩进 - 换行 - 编码'''file:要保存为的文件对象名indent:根节点的缩进方式allindent:子节点的缩进方式newl:针对新行,指明换行方式encoding:保存文件的编码方式'''domTree.writexml(f,indent="",addindent="",newl='',encoding='utf-8')'''整理xml文档的格式,否则xml添加数据,显示的是一行数据,不方便查看'''tree = ElementTree.parse(path)                       # 解析test.xml这个文件root = tree.getroot()                                # 得到根元素,Element类xiugai_xml(root, '\t', '\n')                          # 执行美化方法tree.write("test.xml", encoding = 'utf-8')           # 保存文件

(3)xml文档格式整理,方便查看(换行):

'''xml文档格式整理'''
def xiugai_xml(element, indent, newline, level = 0):# 判断element是否有子元素if element:# 如果element的text没有内容if element.text == None or element.text.isspace():element.text = newline + indent * (level + 1)else:element.text = newline + indent * (level + 1) + element.text.strip() + newline + indent * (level + 1)temp = list(element) # 将elemnt转成listfor subelement in temp:if temp.index(subelement) < (len(temp) - 1):subelement.tail = newline + indent * (level + 1)else: subelement.tail = newline + indent * level   prettyXml(subelement, indent, newline, level = level + 1)

完整代码如下:(xml文件路径,需根据个人路径更改)

#_*_ coding:utf-8 _*_
'''
XML是可扩展标记语言(Extensible Markup Language)的缩写,其中标记是关键部分。
用户可以创建内容,然后使用限定标记标记它,从而使每个单词、短语或块成为可识别、可分类的信息。
'''
#!/usr/bin/python
# -*- coding: UTF-8 -*-from xml.dom.minidom import parse
import xml.dom.minidom
import time
from xml.etree import ElementTreedef read_xml(path_name):            #传递文件路径# 使用minidom解析器打开 XML 文档DOMTree = xml.dom.minidom.parse(path_name)collection = DOMTree.documentElement #获取文档根元素if collection.hasAttribute("shelf"): #获取根元素中shelf的名称print("Root element : %s" % collection.getAttribute("shelf"))# 获取所有关于movie节点下的标签内容movies = collection.getElementsByTagName("movie")  # 打印每部电影的详细信息ii = 1for movie in movies:   #循环movies所有节点,并读取对应标签中的内容数据 print("*****Movie*** %s **部" % i)if movie.hasAttribute("title"):# 获取title节点的名称print("Title: %s" % movie.getAttribute("title"))try:#获取标签中对应标签名称的内容type = movie.getElementsByTagName('type')[0]print("Type: %s" % type.childNodes[0].data)format = movie.getElementsByTagName('format')[0]print ("Format: %s" % format.childNodes[0].data)#修改标签中的内容格式如下:即重新赋值即可,后续标签皆如此写法# format.childNodes[0].data = "textt"rating = movie.getElementsByTagName('rating')[0]print("Rating: %s" % rating.childNodes[0].data)#修改标签中的内容格式如下:即重新赋值即可,后续标签皆如此写法# rating.childNodes[0].data = "textt"stars = movie.getElementsByTagName("stars")[0]print("stars: %s" % stars.childNodes[0].data)description = movie.getElementsByTagName('description')[0]print("Description: %s" % description.childNodes[0].data)i += 1except:pass#XML文档中添加数据
def write_xml():path = "./一/example_2.xml"domTree = parse(path)# 文档根元素rootNode = domTree.documentElement# 新建一个customer节点customer_node = domTree.createElement("movie")customer_node.setAttribute("title", "fuchouzhe")# 创建name节点,并设置textValuename_node = domTree.createElement("type")print(name_node)name_text_value = domTree.createTextNode("kavin")name_node.appendChild(name_text_value)  # 把文本节点挂到name_node节点customer_node.appendChild(name_node)# 创建phone节点,并设置textValuephone_node = domTree.createElement("format")phone_text_value = domTree.createTextNode("32467")phone_node.appendChild(phone_text_value)  # 把文本节点挂到name_node节点customer_node.appendChild(phone_node)# 创建comments节点,这里是CDATAcomments_node = domTree.createElement("stars")cdata_text_value = domTree.createTextNode("ssssss")comments_node.appendChild(cdata_text_value)customer_node.appendChild(comments_node)rootNode.appendChild(customer_node)with open(path, 'w+') as f:# 缩进 - 换行 - 编码'''file:要保存为的文件对象名indent:根节点的缩进方式allindent:子节点的缩进方式newl:针对新行,指明换行方式encoding:保存文件的编码方式'''domTree.writexml(f,indent="",addindent="",newl='',encoding='utf-8')'''整理xml文档的格式,否则xml添加数据,显示的是一行数据,不方便查看'''tree = ElementTree.parse(path)                       # 解析test.xml这个文件root = tree.getroot()                                # 得到根元素,Element类xiugai_xml(root, '\t', '\n')                          # 执行美化方法tree.write("test.xml", encoding = 'utf-8')           # 保存文件'''xml文档格式整理'''
def xiugai_xml(element, indent, newline, level = 0):# 判断element是否有子元素if element:# 如果element的text没有内容if element.text == None or element.text.isspace():element.text = newline + indent * (level + 1)else:element.text = newline + indent * (level + 1) + element.text.strip() + newline + indent * (level + 1)temp = list(element) # 将elemnt转成listfor subelement in temp:if temp.index(subelement) < (len(temp) - 1):subelement.tail = newline + indent * (level + 1)else: subelement.tail = newline + indent * level   prettyXml(subelement, indent, newline, level = level + 1)if __name__ == "__main__":path_name = "./一/example_1.xml"while True:change = input("选择执行的方法 read or write or break:")if change == "read" or change == "1":read_xml(path_name)elif change == "write" or change == "2":write_xml()elif change == "break" or change == "3":breaktime.sleep(2)break

Python-XML文件读取/添加/修改方法记录(一)相关推荐

  1. python txt文件处理软件,对python .txt文件读取及数据处理方法总结

    1.处理包含数据的文件 最近利用python读取txt文件时遇到了一个小问题,就是在计算两个np.narray()类型的数组时,出现了以下错误: 作为一个python新手,遇到这个问题后花费了挺多时间 ...

  2. C# xml文件读取与修改

    c#读写xml文件 已知有一个XML文件(bookstore.xml)如下: Code<?xml version="1.0" encoding="gb2312&qu ...

  3. python读取edi_对python .txt文件读取及数据处理方法总结

    {"moduleinfo":{"card_count":[{"count_phone":1,"count":1}],&q ...

  4. javascript读取xml文件读取节点数据的例子

    分享下用javascript读取xml文件读取节点数据方法. 读取的节点数据,还有一种情况是读取节点属性数据. <head> <title></title> < ...

  5. python修改xml标签的值_对python修改xml文件的节点值方法详解

    这是我的xml文件结构 <?xml version='1.0' encoding='utf-8'?> JPEGImages train_2018-05-08_1000.jpg D:\all ...

  6. C# xml文件的创建,修改和添加节点 。

    最近在做一个项目,设计到xml文件的传输,所以就研究了一下. ,.NET Framework完全支持XML DOM模式,但它不支持SAX模式..NET Framework支持两种不同的分析模式:XML ...

  7. python中shutil.copyfile的用法_用Python复制文件的9个方法

    Python 中有许多"开盖即食"的模块(比如 os,subprocess 和 shutil)以支持文件 I/O 操作.在这篇文章中,你将会看到一些用 Python 实现文件复制的 ...

  8. 用Python复制文件的9个方法(转)

    转自:https://zhuanlan.zhihu.com/p/35725217 用Python复制文件的9个方法 Python 中有许多"开盖即食"的模块(比如 os,subpr ...

  9. Python 复制文件的 9 种方法

    用 Python 复制文件的 9 种方法具体是: shutil copyfile() 方法 shutil copy() 方法 shutil copyfileobj() 方法 shutil copy2( ...

  10. 使用Trados翻译XML文件的三种方法

    XML是The Extensible Markup Language(可扩展标识语言)的缩写,是国际组织W3C于2000年10月6日发布的文件标准格式,目前版本是XML1.0版本,因此,现在越来越多的 ...

最新文章

  1. 剑指offer:面试题10- I. 斐波那契数列
  2. android列表勾选框,android listview实现复选框列表
  3. linux命令more
  4. ES6一些新特性记录
  5. Spring Security——OAuth 2.0 Client自动配置源代码分析
  6. python什么是交换算法_python算法-015将链表元素两两交换元素(交换值、就地翻转)...
  7. Python找出某元素的索引下标
  8. 【MySQL】命令行遇到 ‘> 而无法结束语句编辑的解决方案
  9. 英语学渣如何看懂全英文的芯片数据手册
  10. BT.601和BT.656
  11. 农村小伙从月薪2000多到年薪几十万,我的这条路大多数搬砖人都能走 ǃ
  12. 科研伦理与学术规范(笔记)
  13. Android 小知识记录-----息屏后亮屏并显示Activity在锁屏页面之上
  14. 【硬件和驱动相关】wifi设备没有工作 ubuntu18.0.4 无线网卡 intel 6 AX200
  15. /usr/bin/ld: cannot find -lxxx 问题总结
  16. switch语句用法
  17. 数据库-订单发票表(单表)
  18. 02.Java开发环境搭建
  19. linux大作业聊天室报告,Linux聊天室系统期末大作业.docx
  20. linux(linux常用命令,软件安装,vim编辑器)

热门文章

  1. 在使用QueryRunner时候的异常问题Wrong number of parameters:excepted 0,was given 10 Query
  2. 【python】文件的save和load:npy,npz,txt,csv,pkl,(持更)
  3. OpenBmc开发9:dts简介与使用
  4. 学而思编程python软件下载-靠品牌还是靠实力?猿编程、学而思编程、网易卡搭等机构深度测评...
  5. deepin安装过程
  6. 调用阿里云的通用文字识别-高精版识别接口,识别图片中的文字详解
  7. 计算机键盘中英文,电脑键盘指法练习(英文+数字)
  8. 如何用ps做手绘矢量插画风格照片效果
  9. ds18b20驱动程序Linux,ARM-linux嵌入式内核驱动——DS18B20的驱动
  10. JS中什么是回调函数?