国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python使用minidom讀寫xml的方法

2020-02-23 01:31:27
字體:
來源:轉載
供稿:網友

本文實例講述了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)

<?xml version="1.0" encoding="UTF-8" ?> <employees>   <employee>    <name>l inux </name>   <age> 30 </age>  </employee>  <employee>    <name>windows </name>   <age> 20 </age>  </employee> </employees>

三 使用xml.dom.minidom來讀寫xml
 
1)使用xml.dom.minidom來解析xml:

def TestMiniDom():   from xml.dom import minidom   doc = minidom.parse( "employees.xml" )   # get root element: <employees/>   root = doc.documentElement   # get all children elements: <employee/> <employee/>   employees = root.getElementsByTagName( "employee" )   for employee in employees:     print ( " ------------------------------------------- " )     # element name : employee     print (employee.nodeName)     # element xml content : <employee><name>windows</name><age>20</age></employee>     # 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()            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 乌拉特后旗| 哈尔滨市| 田东县| 溧水县| 宝丰县| 新宁县| 肇庆市| 鹿泉市| 梁山县| 玉屏| 清河县| 太仆寺旗| 汤阴县| 曲周县| 北川| 堆龙德庆县| 纳雍县| 清远市| 山西省| 双桥区| 湟源县| 湘潭县| 南涧| 芜湖县| 高州市| 汉沽区| 延安市| 女性| 柳林县| 辽中县| 安平县| 正定县| 马关县| 达州市| 通许县| 隆林| 建平县| 信阳市| 清涧县| 射洪县| 施甸县|