本篇文章為大家展示了python中如何解析xml文件,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過(guò)這篇文章的詳細(xì)介紹希望你能有所收獲。
成都創(chuàng)新互聯(lián)公司專注于阿克塞哈薩克族自治企業(yè)網(wǎng)站建設(shè),自適應(yīng)網(wǎng)站建設(shè),商城系統(tǒng)網(wǎng)站開(kāi)發(fā)。阿克塞哈薩克族自治網(wǎng)站建設(shè)公司,為阿克塞哈薩克族自治等地區(qū)提供建站服務(wù)。全流程按需開(kāi)發(fā),專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,成都創(chuàng)新互聯(lián)公司專業(yè)和態(tài)度為您提供的服務(wù)
XML 指可擴(kuò)展標(biāo)記語(yǔ)言(eXtensible Markup Language)。
XML 被設(shè)計(jì)用來(lái)傳輸和存儲(chǔ)數(shù)據(jù)。
XML 是一套定義語(yǔ)義標(biāo)記的規(guī)則,這些標(biāo)記將文檔分成許多部件并對(duì)這些部件加以標(biāo)識(shí)。
它也是元標(biāo)記語(yǔ)言,即定義了用于定義其他與特定領(lǐng)域有關(guān)的、語(yǔ)義的、結(jié)構(gòu)化的標(biāo)記語(yǔ)言的句法語(yǔ)言。
常見(jiàn)的 XML 編程接口有 DOM 和 SAX,這兩種接口處理 XML 文件的方式不同,當(dāng)然使用場(chǎng)合也不同。
Python 有三種方法解析 XML,SAX,DOM,以及 ElementTree:
1.SAX (simple API for XML )
Python 標(biāo)準(zhǔn)庫(kù)包含 SAX 解析器,SAX 用事件驅(qū)動(dòng)模型,通過(guò)在解析XML的過(guò)程中觸發(fā)一個(gè)個(gè)的事件并調(diào)用用戶定義的回調(diào)函數(shù)來(lái)處理XML文件。
2.DOM(Document Object Model)
將 XML 數(shù)據(jù)在內(nèi)存中解析成一個(gè)樹(shù),通過(guò)對(duì)樹(shù)的操作來(lái)操作XML。
3.ElementTree(元素樹(shù))
ElementTree就像一個(gè)輕量級(jí)的DOM,具有方便友好的API。代碼可用性好,速度快,消耗內(nèi)存少。
注:因DOM需要將XML數(shù)據(jù)映射到內(nèi)存中的樹(shù),一是比較慢,二是比較耗內(nèi)存,而SAX流式讀取XML文件,比較快,占用內(nèi)存少,但需要用戶實(shí)現(xiàn)回調(diào)函數(shù)(handler)。
country_data.xml文件如下所示:
<?xml version="1.0"?> <data> <country name="Liechtenstein"> <rank>1</rank> <year>2008</year> <gdppc>141100</gdppc> <neighbor name="Austria">
先解釋下一些概念,很簡(jiǎn)單的:
1.第一行的<?xml version="1.0" encoding="UTF-8"?>
是xml文件的聲明,它定義了xml的版本 (1.0)和所使用編碼為UTF-8。
2.接下來(lái)就是xml文件的內(nèi)容了,這些內(nèi)容按一個(gè)樹(shù)狀結(jié)構(gòu)進(jìn)行組織擺放,形式如下:
<root> <child> <subchild>.....</subchild> <subchild>.....</subchild> </child> </root>
其中,每一個(gè)<XXX>.</XXX>
叫做一個(gè)節(jié)點(diǎn),也叫一個(gè)元素,節(jié)點(diǎn)可以嵌套放置,也可以并列放置,在嵌套結(jié)構(gòu)中,內(nèi)外層節(jié)點(diǎn)是父子關(guān)系,以此類推,最外層的節(jié)點(diǎn)都叫做根節(jié)點(diǎn)。并列的兩節(jié)點(diǎn)為兄弟關(guān)系。
3.對(duì)于每一個(gè)節(jié)點(diǎn),一般由Tag、Attribute、Text
三部分構(gòu)成。在country_data.xml中data,country,rank,year
這些都是tag。與tag同一尖括弧內(nèi)右邊的是Attribute
,比如:name
。Text
就是兩個(gè)尖括弧中間夾的東西了。
xml文件的信息都存在節(jié)點(diǎn)里,關(guān)于節(jié)點(diǎn)的遍歷,有好幾種方法,這里用的是Element Tree。代碼如下:
# -*- coding:utf-8 -*- import sys, os.path import xml.etree.ElementTree as ET # 讀取方法 def read_xml(xml_file=''): # 讀取xml文件 tree = ET.parse(xml_file) # 獲取根節(jié)點(diǎn) root = tree.getroot() print("root.tag :", root.tag) # 獲取當(dāng)前根節(jié)點(diǎn)下的所有子country節(jié)點(diǎn) child_node_list = root.findall('country') # 打印每個(gè)country節(jié)點(diǎn)的Attribute for child_node in child_node_list: print('attrib:%s'%child_node.attrib) for child in child_node.getchildren(): print('tag:text;%s:%s'%(child.tag,child.text)) # 獲取某一個(gè)節(jié)點(diǎn)的text,以<rank>234</rank>為例 node = root.find('country2/rank') print(node.text) class XmlParse: def __init__(self, file_path): self.tree = None self.root = None self.xml_file_path = file_path def ReadXml(self): try: print("xmlfile:", self.xml_file_path) # 讀取xml文件 self.tree = ET.parse(self.xml_file_path) # 獲取根節(jié)點(diǎn) self.root = self.tree.getroot() print("root.tag :", self.root.tag) except Exception as e: print("parse xml faild!") sys.exit() else: print("parse xml success!") finally: return self.tree, self.root def CreateNode(self, tag, attrib, text): element = ET.Element(tag, attrib) element.text = text print("tag:%s;attrib:%s;text:%s" % (tag, attrib, text)) return element def AddNode(self, Parent, tag, attrib, text): element = self.CreateNode(tag, attrib, text) if Parent: Parent.append(element) el = self.root.find("Python") print(el.tag, "----", el.attrib, "----", el.text) else: print("parent is none") def WriteXml(self, destfile): dest_xml_file = os.path.abspath(destfile) self.tree.write(dest_xml_file, encoding="utf-8", xml_declaration=True) def method_1(): # 增加節(jié)點(diǎn)并寫(xiě)入新的xml parse = XmlParse(xml_file) tree, root = parse.ReadXml() parse.AddNode(root, "Python", {"age": "22", "hello": "world"}, "YES") parse.WriteXml("./xml/country_data_added.xml") if __name__ == "__main__": xml_file = os.path.abspath("./xml/country_data.xml") read_xml(xml_file=xml_file)# 讀取詳細(xì)方法 # method_1()
xml.dom.minidom官方文檔
# -*- coding:utf-8 -*- from xml.dom.minidom import parse def read_xml(xml_file=''): domTree = parse(xml_file) # 文檔根元素 rootNode = domTree.documentElement #用于得到dom對(duì)象的文檔元素 print('屬性值:',rootNode.nodeName,rootNode.nodeValue,rootNode.nodeType)# 結(jié)點(diǎn)名字,值,類型 customers = rootNode.getElementsByTagName("customer") for customer in customers: if customer.hasAttribute("ID"): print("ID:", customer.getAttribute("ID")) # name 元素 name = customer.getElementsByTagName("name")[0] print(name.nodeName, ":", name.childNodes[0].data) # phone 元素 phone = customer.getElementsByTagName("phone")[0] print(phone.nodeName, ":", phone.childNodes[0].data) # comments 元素 comments = customer.getElementsByTagName("comments")[0] print(comments.nodeName, ":", comments.childNodes[0].data) def write_xml(xml_file=''): domTree = parse(xml_file) # 文檔根元素 rootNode = domTree.documentElement # 新建一個(gè)customer節(jié)點(diǎn) customer_node = domTree.createElement("customer") customer_node.setAttribute("ID", "C003") # 創(chuàng)建name節(jié)點(diǎn),并設(shè)置textValue name_node = domTree.createElement("name") name_text_value = domTree.createTextNode("kavin") name_node.appendChild(name_text_value) # 把文本節(jié)點(diǎn)掛到name_node節(jié)點(diǎn) customer_node.appendChild(name_node) # 創(chuàng)建phone節(jié)點(diǎn),并設(shè)置textValue phone_node = domTree.createElement("phone") phone_text_value = domTree.createTextNode("32467") phone_node.appendChild(phone_text_value) # 把文本節(jié)點(diǎn)掛到name_node節(jié)點(diǎn) customer_node.appendChild(phone_node) # 創(chuàng)建comments節(jié)點(diǎn),這里是CDATA comments_node = domTree.createElement("comments") cdata_text_value = domTree.createCDATASection("A small but healthy company.") comments_node.appendChild(cdata_text_value) customer_node.appendChild(comments_node) rootNode.appendChild(customer_node) with open('./xml/customer_added.xml', 'w') as f: # 縮進(jìn) - 換行 - 編碼 domTree.writexml(f, addindent=' ', newl="", encoding='utf-8') def update_xml(xml_file=''): domTree = parse(xml_file) # 文檔根元素 rootNode = domTree.documentElement names = rootNode.getElementsByTagName("name") for name in names: if name.childNodes[0].data == "Acme Inc.": # 獲取到name節(jié)點(diǎn)的父節(jié)點(diǎn) pn = name.parentNode # 父節(jié)點(diǎn)的phone節(jié)點(diǎn),其實(shí)也就是name的兄弟節(jié)點(diǎn) # 可能有sibNode方法,我沒(méi)試過(guò),大家可以google一下 phone = pn.getElementsByTagName("phone")[0] # 更新phone的取值 phone.childNodes[0].data = 99999 with open('./xml/customer_updated.xml', 'w') as f: # 縮進(jìn) - 換行 - 編碼 domTree.writexml(f, addindent=' ', encoding='utf-8') if __name__ == '__main__': xml_file='./xml/customer.xml' read_xml(xml_file=xml_file) write_xml(xml_file=xml_file) update_xml(xml_file=xml_file)
pyton解析xml時(shí),報(bào)錯(cuò)
是因?yàn)榫幋a的問(wèn)題,把xml的頭
<?xml version="1.0" encoding="gb2312"?>
改成
<?xml version="1.0" encoding="utf-8"?>
上述內(nèi)容就是python中如何解析xml文件,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
網(wǎng)站題目:python中如何解析xml文件
文章地址:http://aaarwkj.com/article26/iipocg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站設(shè)計(jì)、關(guān)鍵詞優(yōu)化、商城網(wǎng)站、網(wǎng)站導(dǎo)航、網(wǎng)站設(shè)計(jì)、網(wǎng)站收錄
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)