Python minidom模塊用法示例【DOM寫入和解析XML】
本文實(shí)例講述了Python minidom模塊用法。分享給大家供大家參考,具體如下:
一、DOM寫XML文件
# -*- coding:utf-8 -*- #!python3 #導(dǎo)入minidom from xml.dom import minidom # 1.創(chuàng)建DOM樹對(duì)象 dom=minidom.Document() # 2.創(chuàng)建根節(jié)點(diǎn)。每次都要用DOM對(duì)象來創(chuàng)建任何節(jié)點(diǎn)。 root_node=dom.createElement('root') # 3.用DOM對(duì)象添加根節(jié)點(diǎn) dom.appendChild(root_node) # 用DOM對(duì)象創(chuàng)建元素子節(jié)點(diǎn) book_node=dom.createElement('book') # 用父節(jié)點(diǎn)對(duì)象添加元素子節(jié)點(diǎn) root_node.appendChild(book_node) # 設(shè)置該節(jié)點(diǎn)的屬性 book_node.setAttribute('price','199') name_node=dom.createElement('name') root_node.appendChild(name_node) # 也用DOM創(chuàng)建文本節(jié)點(diǎn),把文本節(jié)點(diǎn)(文字內(nèi)容)看成子節(jié)點(diǎn) name_text=dom.createTextNode('計(jì)算機(jī)程序設(shè)計(jì)語言 第1版') # 用添加了文本的節(jié)點(diǎn)對(duì)象(看成文本節(jié)點(diǎn)的父節(jié)點(diǎn))添加文本節(jié)點(diǎn) name_node.appendChild(name_text) # 每一個(gè)結(jié)點(diǎn)對(duì)象(包括dom對(duì)象本身)都有輸出XML內(nèi)容的方法,如:toxml()--字符串, toprettyxml()--美化樹形格式。 try: with open('dom_write.xml','w',encoding='UTF-8') as fh: # 4.writexml()第一個(gè)參數(shù)是目標(biāo)文件對(duì)象,第二個(gè)參數(shù)是根節(jié)點(diǎn)的縮進(jìn)格式,第三個(gè)參數(shù)是其他子節(jié)點(diǎn)的縮進(jìn)格式, # 第四個(gè)參數(shù)制定了換行格式,第五個(gè)參數(shù)制定了xml內(nèi)容的編碼。 dom.writexml(fh,indent='',addindent='\t',newl='\n',encoding='UTF-8') print('寫入xml OK!') except Exception as err: print('錯(cuò)誤信息:{0}'.format(err))
生成的dom_write.xml文件結(jié)果如下:
<?xml version="1.0" encoding="UTF-8"?> <root> <book price="199"/> <name>計(jì)算機(jī)程序設(shè)計(jì)語言 第1版</name> </root>
二、DOM解析XML文件
# -*- coding:utf-8 -*- #!python3 from xml.dom import minidom with open('dom_write.xml','r',encoding='utf8') as fh: # parse()獲取DOM對(duì)象 dom=minidom.parse(fh) # 獲取根節(jié)點(diǎn) root=dom.documentElement # 節(jié)點(diǎn)名稱 print(root.nodeName) # 節(jié)點(diǎn)類型:'ELEMENT_NODE',元素節(jié)點(diǎn); 'TEXT_NODE',文本節(jié)點(diǎn); 'ATTRIBUTE_NODE',屬性節(jié)點(diǎn) print(root.nodeType) # 獲取某個(gè)節(jié)點(diǎn)下所有子節(jié)點(diǎn),是個(gè)列表 print(root.childNodes) # 通過dom對(duì)象或根元素,再根據(jù)標(biāo)簽名獲取元素節(jié)點(diǎn),是個(gè)列表 book=root.getElementsByTagName('book')[0] # 獲取節(jié)點(diǎn)屬性 print(book.getAttribute('price')) # 獲取某個(gè)元素節(jié)點(diǎn)的文本內(nèi)容,先獲取子文本節(jié)點(diǎn),然后通過“data”屬性獲取文本內(nèi)容 name=root.getElementsByTagName('name')[0] name_text_node=name.childNodes[0] print(name_text_node.data) # 獲取某節(jié)點(diǎn)的父節(jié)點(diǎn) print(name.parentNode.nodeName)
運(yùn)行輸出:
root
1
[<DOM Text node "'\n\t'">, <DOM Element: book at 0x1dd2800>, <DOM Text node "'\n\t'">, <DOM Element: name at 0x1dd2850>, <DOM Text node "'\n'">]
199
計(jì)算機(jī)程序設(shè)計(jì)語言 第1版
root
PS:這里再為大家提供幾款關(guān)于xml操作的在線工具供大家參考使用:
在線XML/JSON互相轉(zhuǎn)換工具:
http://tools.jb51.net/code/xmljson
在線格式化XML/在線壓縮XML:
http://tools.jb51.net/code/xmlformat
XML在線壓縮/格式化工具:
http://tools.jb51.net/code/xml_format_compress
XML代碼在線格式化美化工具:
http://tools.jb51.net/code/xmlcodeformat
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python操作xml數(shù)據(jù)技巧總結(jié)》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python Socket編程技巧總結(jié)》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進(jìn)階經(jīng)典教程》及《Python文件與目錄操作技巧匯總》
希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。
- Python xmltodict模塊安裝及代碼實(shí)例
- Python lxml模塊的基本使用方法分析
- Python3使用xml.dom.minidom和xml.etree模塊兒解析xml文件封裝函數(shù)的方法
- Python3.5內(nèi)置模塊之shelve模塊、xml模塊、configparser模塊、hashlib、hmac模塊用法分析
- Python利用lxml模塊爬取豆瓣讀書排行榜的方法與分析
- Python使用sax模塊解析XML文件示例
- python遠(yuǎn)程調(diào)用rpc模塊xmlrpclib的方法
- Python3爬蟲爬取百姓網(wǎng)列表并保存為json功能示例【基于request、lxml和json模塊】
- Python基于lxml模塊解析html獲取頁面內(nèi)所有葉子節(jié)點(diǎn)xpath路徑功能示例
- Python利用ElementTree模塊處理XML的方法詳解
- python xml模塊的簡(jiǎn)單使用
相關(guān)文章
基于Python創(chuàng)建可定制的HTTP服務(wù)器
這篇文章主要為大家演示一下如何使用?http.server?模塊來實(shí)現(xiàn)一個(gè)能夠發(fā)布網(wǎng)頁的應(yīng)用服務(wù)器,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2023-05-05Keras目標(biāo)檢測(cè)mtcnn?facenet搭建人臉識(shí)別平臺(tái)
這篇文章主要為大家介紹了Keras目標(biāo)檢測(cè)mtcnn?facenet搭建人臉識(shí)別平臺(tái),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05使用Python發(fā)送郵件附件以定時(shí)備份MySQL的教程
這篇文章主要介紹了使用Python發(fā)送郵件附件以定時(shí)備份MySQL的教程,本文的示例基于CentOS,需要的朋友可以參考下2015-04-04python對(duì)象轉(zhuǎn)字典的兩種實(shí)現(xiàn)方式示例
這篇文章主要介紹了python對(duì)象轉(zhuǎn)字典的兩種實(shí)現(xiàn)方式,結(jié)合實(shí)例形式分析了Python字典與對(duì)象數(shù)據(jù)類型轉(zhuǎn)換相關(guān)操作技巧,需要的朋友可以參考下2019-11-11python3.7+selenium模擬淘寶登錄功能的實(shí)現(xiàn)
這篇文章主要介紹了python3.7+selenium模擬登錄淘寶功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05對(duì)Tensorflow中的變量初始化函數(shù)詳解
今天小編就為大家分享一篇對(duì)Tensorflow中的變量初始化函數(shù)詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-07-07python sklearn庫實(shí)現(xiàn)簡(jiǎn)單邏輯回歸的實(shí)例代碼
Scikit-learn(sklearn)是機(jī)器學(xué)習(xí)中常用的第三方模塊,對(duì)常用的機(jī)器學(xué)習(xí)方法進(jìn)行了封裝,這篇文章主要介紹了python sklearn庫實(shí)現(xiàn)簡(jiǎn)單邏輯回歸的實(shí)例代碼,需要的朋友可以參考下2019-07-07python可視化分析繪制帶趨勢(shì)線的散點(diǎn)圖和邊緣直方圖
這篇文章主要介紹了python可視化分析繪制帶趨勢(shì)線的散點(diǎn)圖和邊緣直方圖,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-06-06基于python+selenium的二次封裝的實(shí)現(xiàn)
這篇文章主要介紹了基于python+selenium的二次封裝的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01