zoukankan      html  css  js  c++  java
  • Python xml处理模块

    ---恢复内容开始---

    xml 通过< >节点来区别数据结构

    ---恢复内容结束---

    xml 通过< >节点来区别数据结构

    <xml version='1.0'>
    <data>
        <country name="USA">
            <rank updated="yes">19</rank>
            <year>2008</year>
            <gdppc>141100</gdppc>
            <neighbor name ="Austria"  direction="E"/>
        </country>
        <country name="Singapore">
            <rank updated="yes">99</rank>
            <year>2008</year>
            <gdppc>141100</gdppc>
            <neighbor name ="Switzerland" direction = "W"/>
        </country>
    </data>
     1 # !/user/bin/python
     2 # -*- coding: utf-8 -*-
     3 
     4 import xml.etree.ElementTree as ET
     5 
     6 tree = ET.parse("xmltest.xml")
     7 root = tree.getroot()  # xml的内存地址
     8 print(root.tag)  # xml中的标签名
     9 
    10 # 遍历xml文件
    11 for child in root:
    12     print(child.tag, child.attrib)
    13     for i in child:
    14         print(i.tag, i.text, i.attrib)
    15 
    16 
    17 # 只遍历year节点
    18 for node in root.iter('year'):
    19     print(node.tag, node.text)
    20 
    21 
    22 # 修改xml文档的内容
    23 for node in root.iter('year'):
    24     new_year = int(node.text)+1
    25     node.text = str(new_year)
    26     node.set("updated", "yes")  # 给year 添加属性updated, 值为yes
    27     node.set("updated by", "Alex")  # 给year 添加属性updated by, 值为Alex
    28 tree.write("xmltest.xml")
    29 
    30 
    31 # 删除node
    32 for country in root.findall("country"):
    33     rank = int(country.fine('rank').text)
    34     if rank > 30:  # rank的值大于30时,删掉相应的国家
    35         root.remove('country')
    36 tree.write("output.xml")
    # !/user/bin/python
    # -*- coding: utf-8 -*-
    
    import xml.etree.ElementTree as ET
    
    new_xml = ET.Element("personinfolist")
    personinfo = ET.SubElement(new_xml, "personinfo", attrib={"enrolled":"yes"})
    name = ET.SubElement(personinfo, "name")
    name.text = "Alex"
    age = ET.SubElement(personinfo, "age", attrib={"checked":"no"})
    sex = ET.SubElement(personinfo, "sex")
    age.text = "33"
    personinfo2 = ET.SubElement(new_xml, "personinfo", attrib={"enrolled":"no"})
    name = ET.SubElement(personinfo2, "name")
    name.text = "Lucy"
    age = ET.SubElement(personinfo2, "age")
    age.text = "10"
    
    et = ET.ElementTree(new_xml)  # 生成文件对象
    et.write("text.xml", encoding='utf-8',xml_declaration=True)
    
    ET.dump(new_xml)  # 打印生成的格式
  • 相关阅读:
    Android NestedScrolling与分发机制 二
    Android NestedScrolling与分发机制
    Android:View随手指移动
    开发错误记录5-Failed to sync Gradle project ‘HideTitleDemo’
    TouchSlop与VelocityTracker认识
    Android判断Touch为滑动事件还是操作控件
    Android-动画简介
    开发错误记录6----友盟社会化分享与支付宝-微信支付问题
    设计模式之抽象工厂模式
    面试题_抽象工厂,字符反串,冒泡与选择排序
  • 原文地址:https://www.cnblogs.com/cheese320/p/9059774.html
Copyright © 2011-2022 走看看