zoukankan      html  css  js  c++  java
  • xml模块

    <?xml version="1.0"?>
    <zaizai>
    <country name="Liechtenstein">
    <rank updated="yes">2</rank>
    <year>2008</year>
    <gdppc>141100</gdppc>
    <neighbor name="Austria" direction="E"/>
    <neighbor name="Switzerland" direction="W"/>
    </country>
    <country name="Singapore">
    <rank updated="yes">5</rank>
    <year>2011</year>
    <gdppc>59900</gdppc>
    <neighbor name="Malaysia" direction="N"/>
    </country>
    <country name="Panama">
    <rank updated="yes">69</rank>
    <year>2011</year>
    <gdppc>13600</gdppc>
    <neighbor name="Costa Rica" direction="W"/>
    <neighbor name="Colombia" direction="E"/>
    </country>

    上面是xml文件,下面是处理xml文件的代码:

    import xml.etree.ElementTree as ET

    tree = ET.parse("xml_test.xml")
    root = tree.getroot()
    print(root.tag)

    # 遍历xml文档
    for child in root:
    print(child.tag, child.attrib)
    for i in child:
    print(i.tag, i.text,i.attrib)

    # 只遍历year 节点
    for node in root.iter('year'):
    print(node.tag, node.text)
    最后是运行结果:

    zaizai
    country {'name': 'Liechtenstein'}
    rank 2 {'updated': 'yes'}
    year 2008 {}
    gdppc 141100 {}
    neighbor None {'name': 'Austria', 'direction': 'E'}
    neighbor None {'name': 'Switzerland', 'direction': 'W'}
    country {'name': 'Singapore'}
    rank 5 {'updated': 'yes'}
    year 2011 {}
    gdppc 59900 {}
    neighbor None {'name': 'Malaysia', 'direction': 'N'}
    country {'name': 'Panama'}
    rank 69 {'updated': 'yes'}
    year 2011 {}
    gdppc 13600 {}
    neighbor None {'name': 'Costa Rica', 'direction': 'W'}
    neighbor None {'name': 'Colombia', 'direction': 'E'}
    year 2008
    year 2011
    year 2011

    修改和删除xml文档:

    import xml.etree.ElementTree as ET

    tree = ET.parse("xmltest.xml")
    root = tree.getroot()

    # 修改
    for node in root.iter('year'):
    new_year = int(node.text) + 1
    node.text = str(new_year)
    node.set("updated", "yes")

    tree.write("xmltest.xml")

    # 删除node
    for country in root.findall('country'):
    rank = int(country.find('rank').text)
    if rank > 50:
    root.remove(country)

    tree.write('output.xml')
     
     
    自己创建xml文档
    
    
    import xml.etree.ElementTree as ET

    new_xml = ET.Element("namelist")
    name = ET.SubElement(new_xml, "name", attrib={"enrolled": "yes"})
    age = ET.SubElement(name, "age", attrib={"checked": "no"})
    sex = ET.SubElement(name, "sex")
    sex.text = '33'
    name2 = ET.SubElement(new_xml, "name", attrib={"enrolled": "no"})
    age = ET.SubElement(name2, "age")
    age.text = '19'

    et = ET.ElementTree(new_xml) # 生成文档对象
    et.write("test.xml", encoding="utf-8", xml_declaration=True)

    ET.dump(new_xml) # 打印生成的格式
     
  • 相关阅读:
    BZOJ 3684 大朋友和多叉树
    Loj #2495. 「AHOI / HNOI2018」转盘
    Loj #2494. 「AHOI / HNOI2018」寻宝游戏
    Loj 2320.「清华集训 2017」生成树计数
    SQL Server 权限管理
    微信和支付宝支付模式详解及实现(.Net标准库)- OSS开源系列
    跨站请求伪造(CSRF)
    require.js入门
    C#中禁止跨线程直接访问控件
    Video.js web视频播放器
  • 原文地址:https://www.cnblogs.com/zaizaiaipython/p/7990404.html
Copyright © 2011-2022 走看看