当前位置:脚本大全 > > 正文

python中random库的用法(Python minidom模块用法示例DOM写入和解析XML)

时间:2021-10-28 10:16:30类别:脚本大全

python中random库的用法

Python minidom模块用法示例DOM写入和解析XML

本文实例讲述了Python minidom模块用法。分享给大家供大家参考,具体如下:

一、DOM写XML文件

  • ?
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • # -*- coding:utf-8 -*-
  • #!python3
  • #导入minidom
  • from xml.dom import minidom
  • # 1.创建DOM树对象
  • dom=minidom.Document()
  • # 2.创建根节点。每次都要用DOM对象来创建任何节点。
  • root_node=dom.createElement('root')
  • # 3.用DOM对象添加根节点
  • dom.appendChild(root_node)
  • # 用DOM对象创建元素子节点
  • book_node=dom.createElement('book')
  • # 用父节点对象添加元素子节点
  • root_node.appendChild(book_node)
  • # 设置该节点的属性
  • book_node.setAttribute('price','199')
  • name_node=dom.createElement('name')
  • root_node.appendChild(name_node)
  • # 也用DOM创建文本节点,把文本节点(文字内容)看成子节点
  • name_text=dom.createTextNode('计算机程序设计语言 第1版')
  • # 用添加了文本的节点对象(看成文本节点的父节点)添加文本节点
  • name_node.appendChild(name_text)
  • # 每一个结点对象(包括dom对象本身)都有输出XML内容的方法,如:toxml()--字符串, toprettyxml()--美化树形格式。
  • try:
  •   with open('dom_write.xml','w',encoding='UTF-8') as fh:
  •     # 4.writexml()第一个参数是目标文件对象,第二个参数是根节点的缩进格式,第三个参数是其他子节点的缩进格式,
  •     # 第四个参数制定了换行格式,第五个参数制定了xml内容的编码。
  •     dom.writexml(fh,indent='',addindent='\t',newl='\n',encoding='UTF-8')
  •     print('写入xml OK!')
  • except Exception as err:
  •   print('错误信息:{0}'.format(err))
  • 生成的dom_write.xml文件结果如下:

  • ?
  • 1
  • 2
  • 3
  • 4
  • 5
  • <?xml version="1.0" encoding="UTF-8"?>
  • <root>
  •  <book price="199"/>
  •  <name>计算机程序设计语言 第1版</name>
  • </root>
  • 二、DOM解析XML文件

  • ?
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • # -*- coding:utf-8 -*-
  • #!python3
  • from xml.dom import minidom
  • with open('dom_write.xml','r',encoding='utf8') as fh:
  •   # parse()获取DOM对象
  •   dom=minidom.parse(fh)
  •   # 获取根节点
  •   root=dom.documentElement
  •   # 节点名称
  •   print(root.nodeName)
  •   # 节点类型:'ELEMENT_NODE',元素节点; 'TEXT_NODE',文本节点; 'ATTRIBUTE_NODE',属性节点
  •   print(root.nodeType)
  •   # 获取某个节点下所有子节点,是个列表
  •   print(root.childNodes)
  •   # 通过dom对象或根元素,再根据标签名获取元素节点,是个列表
  •   book=root.getElementsByTagName('book')[0]
  •   # 获取节点属性
  •   print(book.getAttribute('price'))
  •   # 获取某个元素节点的文本内容,先获取子文本节点,然后通过“data”属性获取文本内容
  •   name=root.getElementsByTagName('name')[0]
  •   name_text_node=name.childNodes[0]
  •   print(name_text_node.data)
  •   # 获取某节点的父节点
  •   print(name.parentNode.nodeName)
  • 运行输出:

    root
    1
    [<DOM Text node "'\n\t'">, <DOM Element: book at 0x1dd2800>, <DOM Text node "'\n\t'">, <DOM Element: name at 0x1dd2850>, <DOM Text node "'\n'">]
    199
    计算机程序设计语言 第1版
    root

    希望本文所述对大家Python程序设计有所帮助。

    原文链接:https://www.cnblogs.com/wcwnina/p/7222180.html

    标签:
    上一篇下一篇

    猜您喜欢

    热门推荐