• XML模块


    XML,可扩展标记语言,用来传输和存储数据。

     xml的文件格式:

    <?xml   version="1.0"   encoding="utf-8"?>      
      <userdata   createuser="false">userdata内容  
          <dataconnection>  
              <server>localhost</server>  
              <uid>sa</uid>  
              <pwd></pwd>  
          </dataconnection>  
          <net>  
              <name>jiayuan</name>  
          </net>  
      </userdata>

    xml中节点Element类的函数

    复制代码
     1 tag                   当前节点标签名
     2 attrib                当前节点属性
     3 text                  当前节点内容
     4 append                添加一个子节点
     5 clear                 清空节点
     6 extend                为当前节点添加 n 个子节点
     7 find                  获取第一个寻找到的子节点
     8 findall               获取所有的子节点
     9 findtext              获取第一个寻找到的子节点的内容
    10 get                   获取当前节点的属性
    11 insert                在当前节点创建子节点,然后插入指定位置
    12 items                 获取当前节点的所有属性,和字典中的items一样,内容都是健值对
    13 iter                  在根据节点名称寻找所有指定的节点,并返回一个迭代器
    14 iterfind              获取所有指定的节点,并放在一个迭代器中
    15 itertext              在子孙中根据节点名称寻找所有指定的节点的内容,并返回一个迭代器
    16 keys                  获取当前节点的所有属性的 key
    17 makeelement           创建一个新节点
    18 remove                删除某个节点
    19 set                   设置当前节点属性
    复制代码

    xml解析

      1.ElementTree.XML(str)函数
    1 from xml.etree import ElementTree as ET
    2 
    3 with open("data.xml",'r') as file:
    4     #将xml文档中内容读取到strXml中
    5     strXml =file.read()
    6     #XML将字符串解析成xml特殊对象,返回xml.etree.ElementTree.Element对象,这个是根节点
    7     root=ET.XML(strXml)
    8     print(type(root))
    XML 
      2.ElementTree.parse("file_path")函数
    1 #打开xml文件并且解析,返回一个xml.etree.ElementTree.ElementTree对象
    2 tree=ET.parse("data.xml")
    3 #获取xml的根节点
    4 root=tree.getroot()
    5 
    6 print(root.tag)
    parse
    
    

     遍历指定的节点

    1 with open("data.xml",'r',encoding="utf-8") as file:
    2     #将xml文档中内容读取到strXml中
    3     strXml =file.read()
    4     #XML将字符串解析成xml特殊对象,返回xml.etree.ElementTree.Element对象,这个是根节点
    5     root=ET.XML(strXml)
    6     for value in root.iter("uid"):
    7         print(value.tag,value.text)
    遍历指定节点

    修改节点的内容并保存

     1 with open("data.xml",'r',encoding="utf-8") as file:
     2     #将xml文档中内容读取到strXml中
     3     strXml =file.read()
     4     #XML将字符串解析成xml特殊对象,返回xml.etree.ElementTree.Element对象,这个是根节点
     5     root=ET.XML(strXml)
     6     node=root.find("dataconnection")
     7     print(node)
     8     node.set("name","hello,xml")
     9 #利用ET.XML这种方法打开XML的话不能直接保存,需要借助ET.ElementTree
    10 #如果使用的ET.parse(filePath)打开的话,就不需要额外的创建一个ElementTree对象
    11     tree=ET.ElementTree(root)
    12     tree.write("data.xml",encoding="utf-8")
    修改并保存
     1 with open("data.xml",'r',encoding="utf-8") as file:
     2     #将xml文档中内容读取到strXml中
     3     strXml =file.read()
     4     #XML将字符串解析成xml特殊对象,返回xml.etree.ElementTree.Element对象,这个是根节点
     5     root=ET.XML(strXml)
     6     node=root.find("dataconnection")
     7     root.remove(node)
     8 #利用ET.XML这种方法打开XML的话不能直接保存,需要借助ET.ElementTree
     9 #如果使用的ET.parse(filePath)打开的话,就不需要额外的创建一个ElementTree对象
    10     tree=ET.ElementTree(root)
    11     tree.write("data.xml",encoding="utf-8")
    删除节点并保存

     创建XML文档

     1 from xml.etree import ElementTree as ET
     2 #创建根节点
     3 root=ET.Element("home",{"name":"root"})
     4 
     5 #创建子节点,也可以用下面的方式创建,但只是创建,还没有加到任何节点下面
     6 #sub=root.makeelement("son",{"sonName":"haha"}),下面同样可以
     7 sub=ET.Element("son",{"sonName":"haha"})
     8 
     9 subsub=ET.Element("subson",{"subsonName":"xixi"})
    10 
    11 root.append(sub)
    12 
    13 sub.append(subsub)
    14 tree=ET.ElementTree(root)
    15 tree.write("createXml.xml")
    16 
    17 ###########结果(实际上是没有缩进的)############
    18 <home name="root">
    19     <son sonName="haha">
    20         <subson subsonName="xixi" />
    21     </son>
    22 </home>
     1 from xml.etree import ElementTree as ET
     2 
     3 root=ET.Element("home",{"name":"root"})
     4 #创建节点并添加到第一个参数的节点下面
     5 sub=ET.SubElement(root,"son",{"subName":"haha"})
     6 
     7 subsub=ET.SubElement(sub,"son",{"subName":"haha"})
     8 
     9 tree=ET.ElementTree(root)
    10 tree.write("createXml2.xml")
    11 
    12 #########结果(结果实际上没有缩进)###########
    13 <home name="root">
    14     <son subName="haha">
    15         <son subName="haha" />
    16     </son>
    17 </home>

    增加缩进

     1 from xml.etree import ElementTree as ET
     2 from xml.dom import minidom
     3 
     4 def prettify(elem):
     5     """
     6     将节点转换成字符串,并添加缩进
     7     """
     8     #返回该对象的字符串表示
     9     rough_string = ET.tostring(elem, 'utf-8')
    10     print(type(rough_string))
    11     #从xml字符串得到dom对象
    12     reparsed = minidom.parseString(rough_string)
    13     print(type(reparsed))
    14     return reparsed.toprettyxml(indent="	")
    15 
    16 root=ET.Element("home",{"name":"root"})
    17 #创建节点并添加到第一个参数的节点下面
    18 sub=ET.SubElement(root,"son",{"subName":"haha"})
    19 
    20 subsub=ET.SubElement(sub,"son",{"subName":"haha"})
    21 
    22 newStr=prettify(root)
    23 
    24 file=open("createXml3.xml","w",encoding="utf-8")
    25 file.write(newStr)
    26 file.close()
    利用xml.dom.minidom增加缩进

    命名空间的使用

     1 from xml.etree import ElementTree as ET
     2 #注册命名空间
     3 ET.register_namespace("baidu","http://baidu.com")
     4 
     5 root=ET.Element("{http://baidu.com}home",{"name":"root"})
     6 #创建节点并添加到第一个参数的节点下面
     7 sub=ET.SubElement(root,"{http://baidu.com}son",{"{http://baidu.com}subName":"haha"})
     8 
     9 subsub=ET.SubElement(sub,"{http://baidu.com}son",{"{http://baidu.com}subName":"xixi"})
    10 
    11 tree=ET.ElementTree(root)
    12 tree.write("createXml4.xml")
    13 
    14 ###########结果(实际中没有缩进)##############
    15 <baidu:home xmlns:baidu="http://baidu.com" name="root">
    16     <baidu:son baidu:subName="haha">
    17         <baidu:son baidu:subName="xixi" />
    18     </baidu:son>
    19 </baidu:home>
    命名空间的使用
  • 相关阅读:
    luogu P3368 【模板】树状数组 2
    dp
    vijos 羽毛
    luogu tyvj 纪念品分组
    codevs 1259 最大正方形子矩阵 WD
    python 序列化之pickle模块 json模块
    python 类的进阶
    python 面向对象与类的基本知识
    python 异常处理
    python time模块 sys模块 collections模块 random模块 os模块 序列化 datetime模块
  • 原文地址:https://www.cnblogs.com/Young-shi/p/11275944.html
Copyright © 2020-2023  润新知