zoukankan      html  css  js  c++  java
  • python xml解析之 xml.etree.ElementTree

    import xml.etree.ElementTree as tree
    import io
    
    
    xml = '''<?xml version="1.0"?>
    <data>
        <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>
    </data>
    '''
    parse = tree.fromstring(xml) #type:tree.Element #根节点
    for e in parse: #遍历
        print(e.tag) # 节点名称
        print(e.attrib.get('name'))#节点属性
    result = parse.findall('country') # 只能找到子节点 第一层
    print(result) #[<Element 'country' at 0x0000000001DDE7C8>, <Element 'country' at 0x000000000291F908>, <Element 'country' at 0x000000000291FA98>]
    
    print([e for e in parse.iter('rank') if e.attrib.get('updated') == 'yes']) #递归遍历所有
    
    #父节点 parse 添加子节点
    print(tree.SubElement(parse, 'test', attrib={'name': 'ceshi'})) #工厂方式添加子节点
    
    print(tree.tostring(parse).decode('utf-8')) #输出xml文档
  • 相关阅读:
    python基础之列表的坑
    python基础之字典篇
    坦克大战[源码] 你懂得
    java例程练习(键盘事件)
    android基础(对话框风格Activity实现)
    android基础(Activity)
    android基础(开发环境搭建)
    android基础(android程序的后台运行问题)
    java(敲 七)
    java例程练习(匿名类用法)
  • 原文地址:https://www.cnblogs.com/alplf123/p/8526736.html
Copyright © 2011-2022 走看看