python xml.etree ElementTree解析 编辑 xml

来源:互联网 发布:linux php log 编辑:程序博客网 时间:2024/05/17 00:06

点击打开原文链接

python有很多种xml解析方式,不过感觉etree的ElementTree 用起来最方便。

复制代码
 1 #coding=utf-8 2 from xml.etree import ElementTree 3  4 import pdb 5  6 def printNodeInfo(node): 7  8     #node.tag 标签名称 9     #node.text 文本属性10     print 'node.tag: %s' %node.tag11 12     #node.attrib 属性字典13     for key in node.attrib:14         print '%s %s' %(key,node.attrib[key])15     return None16 17 def main():18 19     pdb.set_trace()20     try:21         #ElementTree.parse(source,parser=None)22         #将xml文件加载并返回ElementTree 对象23         #parser 是一个可选的参数,如果为空则使用标准的XMLParser24         #step 1: 获取 ElementTree 对象25         xmlDoc = ElementTree.parse('D:\server\map\App.xml')26         #step 2: 获取 根节点27         root = xmlDoc.getroot()28         #root.getchildren() 获取节点 返回的是列表29         gateServerNodeList = root.getchildren()30 31         # 下面是在每个gateServer 节点下 增加一个子节点32         for node in gateServerNodeList:33             # ElementTree.SubElement(parentNode,tagName)34             #给parentNode 增加一个子节点35             #和parentNode.append(Element) 效果一致36             newNode = ElementTree.SubElement(node,'ActiveType')37             # 设置属性 38             newNode.attrib['id'] = '9'39             newNode.attrib['level'] = '38'40             newNode.attrib['begin'] = '201401010000'41             newNode.attrib['end'] = '201401010000'42             #中文 需要 特殊译码43             newNode.attrib['tip'] = '测试'.decode('utf-8')44             #节点尾部的符号45             newNode.tail = '\n'46             #node.append(newNode)47 48         # 写入文件 调用 之前的ElementTree 对象的49         #write(fileName,encoding = None,xml_Decleare = None,default_namespace = None,method = None)50         # 其中xml_Decleare 如果为 True 则 在 文档的最上方会写入51         #<?xml version="1.0" encoding="utf-8"?>52         xmlDoc.write('D:test.xml','utf-8',True)53     except Exception as e:54         print e55         56     return None57 58 if __name__ == '__main__':59     main()
复制代码
0 0
原创粉丝点击