本文实例讲述了python使用minidom读写xml的方法。分享给大家供大家参考。具体分析如下:
一 python提供的xml支持
2种工业标准的xml解析方法-sax和dom。sax(simple api for xml),是基于事件处理的,当xml文档顺序地读入时,每次遇到一个元素会触发相应的事件处理函数来处理。dom(document object model),通过构建一个树结构来表现整个xml文档,一旦树被构建,可以通过dom提供了接口来遍历树和提取相应的数据。
python还提供了python独特的xml解析方法,相比于sax和dom更容易使用和更加快速,此方法为elementtree。
python的xml模块为:
1)xml.dom.minidom
2)xml.elementtree
3)xml.sax + xml.dom
二 xml实例:(employees.xml)
l inux
30
windows
20
三 使用xml.dom.minidom来读写xml
1)使用xml.dom.minidom来解析xml:
def testminidom():
from xml.dom import minidom
doc = minidom.parse( “employees.xml” )
# get root element:
root = doc.documentelement
# get all children elements:
employees = root.getelementsbytagname( “employee” )
for employee in employees:
print ( ” ——————————————- ” )
# element name : employee
print (employee.nodename)
# element xml content : windows20
# basically equal to toprettyxml function
print (employee.toxml())
namenode = employee.getelementsbytagname( “name” )[0]
print (namenode.childnodes)
print (namenode.nodename + “:” + namenode.childnodes[0].nodevalue)
agenode = employee.getelementsbytagname( “age” )[0]
print (agenode.childnodes)
print (agenode.nodename + “:” + agenode.childnodes[0].nodevalue)
print ( ” ——————————————- ” )
for n in employee.childnodes:
print (n)
testminidom()
2)使用xml.dom.minidom来生成xml:
def createxml():
import xml.dom.minidom
impl = xml.dom.minidom.getdomimplementation()
dom = impl.createdocument(none, ’employees’ , none)
root = dom.documentelement
employee = dom.createelement( ’employee’ )
root.appendchild(employee)
namee = dom.createelement( ‘name’ )
namet = dom.createtextnode( ‘linux’ )
namee.appendchild(namet)
employee.appendchild(namee)
agee = dom.createelement( ‘age’ )
aget = dom.createtextnode( ’30’ )
agee.appendchild(aget)
employee.appendchild(agee)
f = open( ’employees2.xml’ , ‘w’)
dom.writexml(f, addindent = ‘ ‘ , newl = ‘\n’ ,encoding = ‘utf-8’ )
f.close()
createxml()
3)使用xml.dom.minidom需要注意的
*使用parse()或createdocument()返回的为dom对象;
*使用dom的documentelement属性可以获得root element;
*dom为树形结构,包含许多的nodes,其中element是node的一种,可以包含子elements,textnode也是node的一种,是最终的子节点;
*每个node都有nodename,nodevalue,nodetype属性,nodevalue是结点的值,只对textnode有效。对于textnode,想得到它的文本内容可以使用: .data属性。
*nodetype是结点的类型,现在有以下:
‘attribute_node”cdata_section_node”comment_node”document_fragment_node’
‘document_node”document_type_node”element_node”entity_node”entity_reference_node’
‘notation_node”processing_instruction_node”text_node’
*getelementsbytagname()可以根据名字来查找子elements;
*childnodes返回所有的子nodes,其中所有的文本均为textnode,包含元素间的‘\n\r’和空格均为textnode;
*writexml() 时addindent=’ ‘表示子元素的缩进,newl=’\n’表示元素间的换行,encoding=’utf-8’表示生成的xml的编码格式()。
希望本文所述对大家的python程序设计有所帮助。