python xml读取和写入
先说说如何建设一个XML文件吧
# -*- coding: utf-8 -*- from xml.dom import minidom impl = minidom.getDOMImplementation() dom = impl.createDocument(None, None, None)#namespaceURI, qualifiedName, doctype #write to dom root = dom.createElement("skills") for skillid in range(10): skill= dom.createElement('skill') skill.setAttribute('id', str(skillid)) root.appendChild( skill ) dom.appendChild( root ) #end write to dom #writexml(writer, indent, addindent, newl, encoding) #writer是文件工具 #indent是每个tag前填充的字符,如:' ',则暗示每个tag前有两个空格 #addindent是每个子结点的缩近字符 #newl是每个tag后填充的字符,如:'\n',则暗示每个tag后头有一个回车 #encoding是生成的XML信息头中的encoding属性值, # 在输出时minidom并不真正举办编码的处理惩罚,假如你生存的文本内容中有汉字, # 则需要自已举办编码转换。 f=file('c:\\skills.xml','w') dom.writexml(f,'',' ','\n','utf-8') f.close()
这样生成的XM了如下:
<?xml version="1.0" encoding="utf-8"?>
<skills>
<skill id="0"/>
<skill id="1"/>
<skill id="2"/>
<skill id="3"/>
<skill id="4"/>
<skill id="5"/>
<skill id="6"/>
<skill id="7"/>
<skill id="8"/>
<skill id="9"/>
</skills>
#######################
读取XML
>>> dom = xml.dom.minidom.parse('c:/skills.xml')
>>> root = dom.documentElement
>>> root.nodeName
>>> r2.nodeName
u'skills'