电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

python解析xml文件方式(解析、更新、寫入)

瀏覽:75日期:2022-08-03 16:58:22

Overview

這篇博客內(nèi)容將包括對XML文件的解析、追加新元素后寫入到XML,以及更新原XML文件中某結(jié)點(diǎn)的值。使用的是python的xml.dom.minidom包,詳情可見其官方文檔:xml.dom.minidom官方文檔。全文都將圍繞以下的customer.xml進(jìn)行操作:

<?xml version='1.0' encoding='utf-8' ?><!-- This is list of customers --><customers> <customer ID='C001'> <name>Acme Inc.</name> <phone>12345</phone> <comments> <![CDATA[Regular customer since 1995]]> </comments> </customer> <customer ID='C002'> <name>Star Wars Inc.</name> <phone>23456</phone> <comments> <![CDATA[A small but healthy company.]]> </comments> </customer></customers>

CDATA:在XML中,不會被解析器解析的部分?jǐn)?shù)據(jù)。

聲明:在本文中,結(jié)點(diǎn)和節(jié)點(diǎn)被視為了同一個(gè)概念,你可以在全文的任何地方替換它,我個(gè)人感覺區(qū)別不是很大,當(dāng)然,你也可以看做是我的打字輸入錯(cuò)誤。

1. 解析XML文件

在解析XML時(shí),所有的文本都是儲存在文本節(jié)點(diǎn)中的,且該文本節(jié)點(diǎn)被視為元素結(jié)點(diǎn)的子結(jié)點(diǎn),例如:2005,元素節(jié)點(diǎn) ,擁有一個(gè)值為 “2005” 的文本節(jié)點(diǎn),“2005” 不是 元素的值,最常用的方法就是getElementsByTagName()方法了,獲取到結(jié)點(diǎn)后再進(jìn)一步根據(jù)文檔結(jié)構(gòu)解析即可。

具體的理論就不過多描述,配合上述XML文件和下面的代碼,你將清楚的看到操作方法,下面的代碼執(zhí)行的工作是將所有的結(jié)點(diǎn)名稱以及結(jié)點(diǎn)信息輸出一下:

# -*- coding: utf-8 -*-''' @Author : LiuZhian @Time : 2019/4/24 0024 上午 9:19 @Comment : '''from xml.dom.minidom import parsedef readXML(): domTree = parse('./customer.xml') # 文檔根元素 rootNode = domTree.documentElement print(rootNode.nodeName) # 所有顧客 customers = rootNode.getElementsByTagName('customer') print('****所有顧客信息****') 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)if __name__ == ’__main__’: readXML()

python解析xml文件方式(解析、更新、寫入)

2. 寫入XML文件

在寫入時(shí),我覺得可分為兩種方式:

新建一個(gè)全新的XML文件

在已有XML文件基礎(chǔ)上追加一些元素信息

至于以上兩種情況,其實(shí)創(chuàng)建元素結(jié)點(diǎn)的方法類似,你必須要做的都是先創(chuàng)建/得到一個(gè)DOM對象,再在DOM基礎(chǔ)上創(chuàng)建new一個(gè)新的結(jié)點(diǎn)。

如果是第一種情況,你可以通過dom=minidom.Document()來創(chuàng)建;如果是第二種情況,直接可以通過解析已有XML文件來得到dom對象,例如dom = parse('./customer.xml')

在具體創(chuàng)建元素/文本結(jié)點(diǎn)時(shí),你大致會寫出像以下這樣的“四部曲”代碼:

①創(chuàng)建一個(gè)新元素結(jié)點(diǎn)createElement()

②創(chuàng)建一個(gè)文本節(jié)點(diǎn)createTextNode()

③將文本節(jié)點(diǎn)掛載元素結(jié)點(diǎn)上

④將元素結(jié)點(diǎn)掛載到其父元素上。

現(xiàn)在,我需要新建一個(gè)customer節(jié)點(diǎn),信息如下:

<customer ID='C003'> <name>kavin</name> <phone>32467</phone> <comments> <![CDATA[A small but healthy company.]]> </comments> </customer>

代碼如下:

def writeXML(): domTree = parse('./customer.xml') # 文檔根元素 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(’added_customer.xml’, ’w’) as f: # 縮進(jìn) - 換行 - 編碼 domTree.writexml(f, addindent=’ ’, encoding=’utf-8’)if __name__ == ’__main__’: writeXML()

python解析xml文件方式(解析、更新、寫入)

3. 更新XML文件

在更新XML時(shí),只需先找到對應(yīng)的元素結(jié)點(diǎn),然后將其下的文本結(jié)點(diǎn)或?qū)傩匀≈蹈录纯桑缓蟊4娴轿募唧w我就不多說了,代碼中我將思路都注釋清楚了,如下:

def updateXML(): domTree = parse('./customer.xml') # 文檔根元素 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方法,我沒試過,大家可以google一下 phone = pn.getElementsByTagName('phone')[0] # 更新phone的取值 phone.childNodes[0].data = 99999 with open(’updated_customer.xml’, ’w’) as f: # 縮進(jìn) - 換行 - 編碼 domTree.writexml(f, addindent=’ ’, encoding=’utf-8’)if __name__ == ’__main__’: updateXML()

python解析xml文件方式(解析、更新、寫入)

如有不對之處,還煩請指教~

補(bǔ)充知識:python 讀取xml文件內(nèi)容并完成修改

我就廢話不多說了,還是直接看代碼吧!

import osimport xml.etree.ElementTree as ETdef changesku(inputpath): listdir = os.listdir(inputpath) for file in listdir: if file.endswith(’xml’): file = os.path.join(inputpath,file) tree = ET.parse(file) root = tree.getroot() for object1 in root.findall(’object’): #我要修改的元素在object里面,所以需要先找到objectfor sku in object1.findall(’name’): #查找想要修改的所有同種元素 if (sku.text == ’005’): #‘005’為原始的text sku.text = ’008’ #修改‘name’的標(biāo)簽值 tree.write(file,encoding=’utf-8’) #寫進(jìn)原始的xml文件,不然修改就無效,‘encoding = “utf - 8”’避免原始xml #中文字符亂碼 else: pass else: passif __name__ == ’__main__’: inputpath = ’D:easyhebing_xml’ #這是xml文件的文件夾的絕對地址 changesku(inputpath)

以上這篇python解析xml文件方式(解析、更新、寫入)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 除甲醛公司-甲醛检测治理-杭州创绿家环保科技有限公司-室内空气净化十大品牌 | 上海心叶港澳台联考一对一培训_上海心叶港澳台联考,港澳台联考一对一升学指导 | 隧道风机_DWEX边墙风机_SDS射流风机-绍兴市上虞科瑞风机有限公司 | 天津拓展_天津团建_天津趣味运动会_天津活动策划公司-天津华天拓展培训中心 | 太平洋亲子网_健康育儿 品质生活 | 座椅式升降机_无障碍升降平台_残疾人升降平台-南京明顺机械设备有限公司 | 哈尔滨京科脑康神经内科医院-哈尔滨治疗头痛医院-哈尔滨治疗癫痫康复医院 | OpenI 启智 新一代人工智能开源开放平台 | 气弹簧定制-气动杆-可控气弹簧-不锈钢阻尼器-工业气弹簧-可调节气弹簧厂家-常州巨腾气弹簧供应商 | 不锈钢水箱生产厂家_消防水箱生产厂家-河南联固供水设备有限公司 | 分子精馏/精馏设备生产厂家-分子蒸馏工艺实验-新诺舜尧(天津)化工设备有限公司 | 电动高尔夫球车|电动观光车|电动巡逻车|电动越野车厂家-绿友机械集团股份有限公司 | 两头忙,井下装载机,伸缩臂装载机,30装载机/铲车,50装载机/铲车厂家_价格-莱州巨浪机械有限公司 | 众品家具网-家具品牌招商_家具代理加盟_家具门户的首选网络媒体。 | 石磨面粉机|石磨面粉机械|石磨面粉机组|石磨面粉成套设备-河南成立粮油机械有限公司 | 拼装地板,悬浮地板厂家,悬浮式拼装运动地板-石家庄博超地板科技有限公司 | 河南砖机首页-全自动液压免烧砖机,小型砌块水泥砖机厂家[十年老厂] | 温州中研白癜风专科_温州治疗白癜风_温州治疗白癜风医院哪家好_温州哪里治疗白癜风 | 祝融环境-地源热泵多恒系统高新技术企业,舒适生活环境缔造者! | 深圳VI设计-画册设计-LOGO设计-包装设计-品牌策划公司-[智睿画册设计公司] | 济南展厅设计施工_数字化展厅策划设计施工公司_山东锐尚文化传播有限公司 | 数显恒温培养摇床-卧式/台式恒温培养摇床|朗越仪器 | 寮步纸箱厂_东莞纸箱厂 _东莞纸箱加工厂-东莞市寮步恒辉纸制品厂 | 对照品_中药对照品_标准品_对照药材_「格利普」高纯中药标准品厂家-成都格利普生物科技有限公司 澳门精准正版免费大全,2025新澳门全年免费,新澳天天开奖免费资料大全最新,新澳2025今晚开奖资料,新澳马今天最快最新图库 | 环讯传媒,永康网络公司,永康网站建设,永康小程序开发制作,永康网站制作,武义网页设计,金华地区网站SEO优化推广 - 永康市环讯电子商务有限公司 | 不锈钢酒柜|恒温酒柜|酒柜定制|酒窖定制-上海啸瑞实业有限公司 | 下水道疏通_管道疏通_马桶疏通_附近疏通电话- 立刻通 | 中天寰创-内蒙古钢结构厂家|门式刚架|钢结构桁架|钢结构框架|包头钢结构煤棚 | VI设计-LOGO设计公司-品牌设计公司-包装设计公司-导视设计-杭州易象设计 | 万濠投影仪_瑞士TRIMOS高度仪_尼康投影仪V12BDC|量子仪器 | 管家婆-管家婆软件-管家婆辉煌-管家婆进销存-管家婆工贸ERP | 大立教育官网-一级建造师培训-二级建造师培训-造价工程师-安全工程师-监理工程师考试培训 | 恒温振荡混匀器-微孔板振荡器厂家-多管涡旋混匀器厂家-合肥艾本森(www.17world.net) | 北京开源多邦科技发展有限公司官网 | 粘度计维修,在线粘度计,二手博勒飞粘度计维修|收购-天津市祥睿科技有限公司 | 车件|铜件|车削件|车床加工|五金冲压件-PIN针,精密车件定制专业厂商【东莞品晔】 | TMT观察网_独特视角观察TMT行业 派财经_聚焦数字经济内容服务平台 | 诺冠气动元件,诺冠电磁阀,海隆防爆阀,norgren气缸-山东锦隆自动化科技有限公司 | 行业分析:提及郑州火车站附近真有 特殊按摩 ?2025实地踩坑指南 新手如何避坑不踩雷 | 大米加工设备|大米加工机械|碾米成套设备|大米加工成套设备-河南成立粮油机械有限公司 | 门禁卡_智能IC卡_滴胶卡制作_硅胶腕带-卡立方rfid定制厂家 |