Python实现的读取/更改/写入xml文件操作示例


Posted in Python onAugust 30, 2018

本文实例讲述了Python实现的读取/更改/写入xml文件操作。分享给大家供大家参考,具体如下:

原始文档内容(test.xml):

<?xml version="1.0" encoding="UTF-8"?>
<framework>
  <processers>
    <processer name="AProcesser" file="lib64/A.so"
      path="/tmp">
    </processer>
    <processer name="BProcesser" file="lib64/B.so" value="fordelete">
    </processer>
    <processer name="BProcesser" file="lib64/B.so2222222"/>
    <services>
      <service name="search" prefix="/bin/search?"
        output_formatter="OutPutFormatter:service_inc">
        <chain sequency="chain1"/>
        <chain sequency="chain2"></chain>
      </service>
      <service name="update" prefix="/bin/update?">
        <chain sequency="chain3" value="fordelete"/>
      </service>
    </services>
  </processers>
</framework>

Python操作xml代码:

# -*- coding:utf-8 -*-
'''
Created on 2018年8月30日
@author: Administrator
'''
from xml.etree.ElementTree import ElementTree,Element
def read_xml(in_path):
  '''''读取并解析xml文件
    in_path: xml路径
    return: ElementTree'''
  tree = ElementTree()
  tree.parse(in_path)
  return tree
def write_xml(tree, out_path):
  '''''将xml文件写出
    tree: xml树
    out_path: 写出路径'''
  tree.write(out_path, encoding="utf-8",xml_declaration=True)
def if_match(node, kv_map):
  '''''判断某个节点是否包含所有传入参数属性
    node: 节点
    kv_map: 属性及属性值组成的map'''
  for key in kv_map:
    if node.get(key) != kv_map.get(key):
      return False
  return True
#---------------search -----
def find_nodes(tree, path):
  '''''查找某个路径匹配的所有节点
    tree: xml树
    path: 节点路径'''
  return tree.findall(path)
def get_node_by_keyvalue(nodelist, kv_map):
  '''''根据属性及属性值定位符合的节点,返回节点
    nodelist: 节点列表
    kv_map: 匹配属性及属性值map'''
  result_nodes = []
  for node in nodelist:
    if if_match(node, kv_map):
      result_nodes.append(node)
  return result_nodes
#---------------change -----
def change_node_properties(nodelist, kv_map, is_delete=False):
  '''''修改/增加 /删除 节点的属性及属性值
    nodelist: 节点列表
    kv_map:属性及属性值map'''
  for node in nodelist:
    for key in kv_map:
      if is_delete:
        if key in node.attrib:
          del node.attrib[key]
      else:
        node.set(key, kv_map.get(key))
def change_node_text(nodelist, text, is_add=False, is_delete=False):
  '''''改变/增加/删除一个节点的文本
    nodelist:节点列表
    text : 更新后的文本'''
  for node in nodelist:
    if is_add:
      node.text += text
    elif is_delete:
      node.text = ""
    else:
      node.text = text
def create_node(tag, property_map, content):
  '''''新造一个节点
    tag:节点标签
    property_map:属性及属性值map
    content: 节点闭合标签里的文本内容
    return 新节点'''
  element = Element(tag, property_map)
  element.text = content
  return element
def add_child_node(nodelist, element):
  '''''给一个节点添加子节点
    nodelist: 节点列表
    element: 子节点'''
  for node in nodelist:
    node.append(element)
def del_node_by_tagkeyvalue(nodelist, tag, kv_map):
  '''''同过属性及属性值定位一个节点,并删除之
    nodelist: 父节点列表
    tag:子节点标签
    kv_map: 属性及属性值列表'''
  for parent_node in nodelist:
    children = parent_node.getchildren()
    for child in children:
      if child.tag == tag and if_match(child, kv_map):
        parent_node.remove(child)
if __name__ == "__main__":
  #1. 读取xml文件
  tree = read_xml("D://test.xml")
  #2. 属性修改
  #A. 找到父节点
  nodes = find_nodes(tree, "processers/processer")
  #B. 通过属性准确定位子节点
  result_nodes = get_node_by_keyvalue(nodes, {"name":"BProcesser"})
  #C. 修改节点属性
  change_node_properties(result_nodes, {"age": "1"})
  #D. 删除节点属性
  change_node_properties(result_nodes, {"value":""}, True)
  #3. 节点修改
  #A.新建节点
  a = create_node("person", {"age":"15","money":"200000"}, "this is the firest content")
  #B.插入到父节点之下
  add_child_node(result_nodes, a)
  #4. 删除节点
  #定位父节点
  del_parent_nodes = find_nodes(tree, "processers/services/service")
  #准确定位子节点并删除之
  target_del_node = del_node_by_tagkeyvalue(del_parent_nodes, "chain", {"sequency" : "chain1"})
  #5. 修改节点文本
  #定位节点
  text_nodes = get_node_by_keyvalue(find_nodes(tree, "processers/services/service/chain"), {"sequency":"chain3"})
  change_node_text(text_nodes, "new text")
  #6. 输出到结果文件
  write_xml(tree, "D://xiugai.xml")

更改之后的内容(xiugai.xml):

<?xml version='1.0' encoding='utf-8'?>
<framework>
  <processers>
    <processer file="lib64/A.so" name="AProcesser" path="/tmp">
    </processer>
    <processer age="1" file="lib64/B.so" name="BProcesser">
    <person age="15" money="200000">this is the firest content</person></processer>
    <processer age="1" file="lib64/B.so2222222" name="BProcesser"><person age="15" money="200000">this is the firest content</person></processer>
    <services>
      <service name="search" output_formatter="OutPutFormatter:service_inc" prefix="/bin/search?">
        <chain sequency="chain2" />
      </service>
      <service name="update" prefix="/bin/update?">
        <chain sequency="chain3" value="fordelete">new text</chain>
      </service>
    </services>
  </processers>
</framework>
Python 相关文章推荐
python正则表达式判断字符串是否是全部小写示例
Dec 25 Python
Python时间模块datetime、time、calendar的使用方法
Jan 13 Python
Python卸载模块的方法汇总
Jun 07 Python
Django中使用极验Geetest滑动验证码过程解析
Jul 31 Python
python中利用numpy.array()实现俩个数值列表的对应相加方法
Aug 26 Python
Python从文件中读取指定的行以及在文件指定位置写入
Sep 06 Python
Python实现线性插值和三次样条插值的示例代码
Nov 13 Python
Django DRF APIView源码运行流程详解
Aug 17 Python
pip 20.3 新版本发布!即将抛弃 Python 2.x(推荐)
Dec 16 Python
10张动图学会python循环与递归问题
Feb 06 Python
如何将numpy二维数组中的np.nan值替换为指定的值
May 14 Python
python之django路由和视图案例教程
Jul 26 Python
python实现录音小程序
Oct 26 #Python
Python图像处理之简单画板实现方法示例
Aug 30 #Python
浅析python中numpy包中的argsort函数的使用
Aug 30 #Python
浅析python3中的os.path.dirname(__file__)的使用
Aug 30 #Python
python语音识别实践之百度语音API
Aug 30 #Python
python调用百度语音识别实现大音频文件语音识别功能
Aug 30 #Python
python的中异常处理机制
Aug 30 #Python
You might like
PHP EOT定界符的使用详解
2008/09/30 PHP
PHP类的反射用法实例
2014/11/03 PHP
PHP读书笔记_运算符详解
2016/07/01 PHP
php 常用的系统函数
2017/02/07 PHP
PHP实现正则表达式分组捕获操作示例
2018/02/03 PHP
5秒后跳转到另一个页面的js代码
2013/10/12 Javascript
JQuery中使用on方法绑定hover事件实例
2014/12/09 Javascript
jQuery中animate用法实例分析
2015/03/09 Javascript
JavaScript中textRange对象使用方法小结
2015/03/24 Javascript
简单介绍JavaScript数据类型之隐式类型转换
2015/12/28 Javascript
总结JavaScript三种数据存储方式之间的区别
2016/05/03 Javascript
详解JavaScript设计模式开发中的桥接模式使用
2016/05/18 Javascript
javascript运算符——逻辑运算符全面解析
2016/06/27 Javascript
JS仿QQ好友列表展开、收缩功能(第一篇)
2017/07/07 Javascript
vue-router重定向和路由别名的使用讲解
2019/01/19 Javascript
layUI实现前端分页和后端分页
2019/07/27 Javascript
JS函数进阶之prototy用法实例分析
2020/01/15 Javascript
Vue的双向数据绑定实现原理解析
2020/02/17 Javascript
Python getopt模块处理命令行选项实例
2014/05/13 Python
python输出当前目录下index.html文件路径的方法
2015/04/28 Python
python绘制简单折线图代码示例
2017/12/19 Python
Python Socket编程之多线程聊天室
2018/07/28 Python
在unittest中使用 logging 模块记录测试数据的方法
2018/11/30 Python
使用Tkinter制作信息提示框
2020/02/18 Python
HTML5 canvas基本绘图之绘制线段
2016/06/27 HTML / CSS
Joe Fresh官网:加拿大时尚品牌和零售连锁店
2016/11/30 全球购物
C语言笔试题
2014/09/04 面试题
工地资料员岗位职责
2013/12/31 职场文书
导游实习生自荐书
2014/01/28 职场文书
诚信考试承诺书
2014/03/27 职场文书
八项规定个人对照检查材料思想汇报
2014/09/25 职场文书
2015年体育部工作总结
2015/04/02 职场文书
2015年行政工作总结范文
2015/04/09 职场文书
聚众斗殴罪辩护词
2015/05/21 职场文书
《红领巾真好》教学反思
2016/02/16 职场文书
box-shadow单边阴影的实现
2023/05/21 HTML / CSS