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文档

 

posted @ 2018-03-08 10:04  我是外婆  阅读(1735)  评论(0编辑  收藏  举报