Python使用minidom讀寫xml的方法
本文實(shí)例講述了Python使用minidom讀寫xml的方法。分享給大家供大家參考。具體分析如下:
一 python提供的xml支持
2種工業(yè)標(biāo)準(zhǔn)的xml解析方法-SAX和DOM。SAX(simple API for XML),是基于事件處理的,當(dāng)XML文檔順序地讀入時(shí),每次遇到一個(gè)元素會(huì)觸發(fā)相應(yīng)的事件處理函數(shù)來處理。DOM(Document Object Model),通過構(gòu)建一個(gè)樹結(jié)構(gòu)來表現(xiàn)整個(gè)xml文檔,一旦樹被構(gòu)建,可以通過DOM提供了接口來遍歷樹和提取相應(yīng)的數(shù)據(jù)。
python還提供了python獨(dú)特的xml解析方法,相比于SAX和DOM更容易使用和更加快速,此方法為ElementTree。
python的xml模塊為:
1)xml.dom.minidom
2)xml.elementtree
3)xml.sax + xml.dom
二 xml實(shí)例:(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()
3)使用xml.dom.minidom需要注意的
*使用parse()或createDocument()返回的為DOM對(duì)象;
*使用DOM的documentElement屬性可以獲得Root Element;
*DOM為樹形結(jié)構(gòu),包含許多的nodes,其中element是node的一種,可以包含子elements,textNode也是node的一種,是最終的子節(jié)點(diǎn);
*每個(gè)node都有nodeName,nodeValue,nodeType屬性,nodeValue是結(jié)點(diǎn)的值,只對(duì)textNode有效。對(duì)于textNode,想得到它的文本內(nèi)容可以使用: .data屬性。
*nodeType是結(jié)點(diǎn)的類型,現(xiàn)在有以下:
'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()可以根據(jù)名字來查找子elements;
*childNodes返回所有的子Nodes,其中所有的文本均為textNode,包含元素間的‘\n\r'和空格均為textNode;
*writexml() 時(shí)addindent=' '表示子元素的縮進(jìn),newl='\n'表示元素間的換行,encoding='utf-8'表示生成的xml的編碼格式(<?xml version="1.0" encoding="utf-8"?>)。
希望本文所述對(duì)大家的Python程序設(shè)計(jì)有所幫助。
- python讀寫ini文件示例(python讀寫文件)
- python 3.74 運(yùn)行import numpy as np 報(bào)錯(cuò)lib\site-packages\numpy\__init__.py
- Python讀寫ini文件的方法
- Python操作配置文件ini的三種方法講解
- Python中使用ConfigParser解析ini配置文件實(shí)例
- Python讀取配置文件(config.ini)以及寫入配置文件
- Python讀取ini文件、操作mysql、發(fā)送郵件實(shí)例
- python構(gòu)造函數(shù)init實(shí)例方法解析
- 使用python腳本自動(dòng)創(chuàng)建pip.ini配置文件代碼實(shí)例
- python對(duì)配置文件.ini進(jìn)行增刪改查操作的方法示例
- Python 使用ConfigParser操作ini配置文件
相關(guān)文章
將Django項(xiàng)目遷移到linux系統(tǒng)的詳細(xì)步驟
這篇文章主要介紹了將Django項(xiàng)目遷移到linux系統(tǒng)的詳細(xì)步驟,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03
python中for循環(huán)輸出列表索引與對(duì)應(yīng)的值方法
今天小編就為大家分享一篇python中for循環(huán)輸出列表索引與對(duì)應(yīng)的值方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-11-11
Django網(wǎng)絡(luò)框架之HelloDjango項(xiàng)目創(chuàng)建教程
這篇文章主要介紹了Django網(wǎng)絡(luò)框架之HelloDjango項(xiàng)目創(chuàng)建,結(jié)合實(shí)例形式詳細(xì)分析了Django框架創(chuàng)建HelloDjango項(xiàng)目的具體步驟與詳細(xì)實(shí)現(xiàn)技巧,需要的朋友可以參考下2019-06-06
解決運(yùn)行django程序出錯(cuò)問題 ''str''object has no attribute''_meta''
這篇文章主要介紹了解決運(yùn)行django程序出錯(cuò)問題 'str'object has no attribute'_meta',具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-07-07
python 實(shí)現(xiàn)超級(jí)瑪麗游戲
這篇文章主要介紹了python 實(shí)現(xiàn)超級(jí)瑪麗游戲,幫助大家更好的理解和使用python開發(fā)游戲,感興趣的朋友可以了解下2020-11-11
python數(shù)字圖像處理之高級(jí)濾波代碼詳解
這篇文章主要介紹了python數(shù)字圖像處理之高級(jí)濾波代碼詳解,介紹了許多對(duì)圖像處理的濾波方法,具有一定參考價(jià)值,需要的朋友可以了解下。2017-11-11
Python復(fù)制Excel表格中指定數(shù)據(jù)若干次的方法
本文介紹基于Python語言,讀取Excel表格文件數(shù)據(jù),并基于其中某一列數(shù)據(jù)的值,將這一數(shù)據(jù)處于指定范圍的那一行加以復(fù)制,并將所得結(jié)果保存為新的Excel表格文件的方法,需要的朋友可以參考下2024-02-02

