国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

基于Python的XML格式的文件示例代碼詳解

瀏覽:2日期:2022-06-24 15:43:26

XML文件是可拓展標記語言,是一種簡單的數(shù)據(jù)存儲語言,被設(shè)計用來傳輸和存儲數(shù)據(jù)

在Python中XML的一些方法

讀取文件和內(nèi)容

#引用xml模塊from xml.etree import ElementTree as ET# ET去打開xml文件tree = ET.parse('files/xo.xml')# 獲取根標簽root = tree.getroot()print(root) # <Element ’data’ at 0x7f94e02763b0>

from xml.etree import ElementTree as ETcontent = '''<data> <country name='Liechtenstein'> <rank updated='yes'>2</rank> <year>2023</year> <gdppc>141100</gdppc> <neighbor direction='E' name='Austria' /> <neighbor direction='W' name='Switzerland' /> </country> <country name='Panama'> <rank updated='yes'>69</rank> <year>2026</year> <gdppc>13600</gdppc> <neighbor direction='W' name='Costa Rica' /> <neighbor direction='E' name='Colombia' /> </country></data>'''root = ET.XML(content) # 獲取根標簽 print(root) # <Element ’data’ at 0x7fdaa019cea0>

讀取節(jié)點數(shù)據(jù)

from xml.etree import ElementTree as ETcontent = '''<data> <country name='Liechtenstein' > <rank>2</rank> <year>2023</year> <gdppc>141100</gdppc> <neighbor direction='E' name='Austria' /> <neighbor direction='W' name='Switzerland' /> </country> <country name='Panama'> <rank>69</rank> <year>2026</year> <gdppc>13600</gdppc> <neighbor direction='W' name='Costa Rica' /> <neighbor direction='E' name='Colombia' /> </country></data>'''# 獲取根標簽 dataroot = ET.XML(content)country_object = root.find('country') # 獲取XML文件中的country標簽print(country_object.tag, country_object.attrib)# 獲取country標簽名 獲取country標簽地屬性gdppc_object = country_object.find('gdppc')# 獲取gdppc標簽print(gdppc_object.tag,gdppc_object.attrib,gdppc_object.text)# 獲取gdppc標簽的名稱 獲取gdppc屬性(沒有屬性為:{}) 獲取gdppc標簽里面的內(nèi)容

from xml.etree import ElementTree as ETcontent = '''<data> <country name='Liechtenstein'> <rank>2</rank> <year>2023</year> <gdppc>141100</gdppc> <neighbor direction='E' name='Austria' /> <neighbor direction='W' name='Switzerland' /> </country> <country name='Panama'> <rank>69</rank> <year>2026</year> <gdppc>13600</gdppc> <neighbor direction='W' name='Costa Rica' /> <neighbor direction='E' name='Colombia' /> </country></data>'''# 獲取根標簽 dataroot = ET.XML(content)# 獲取data標簽的孩子標簽for child in root: # child.tag = conntry 獲取到兩個country標簽 # child.attrib = {'name':'Liechtenstein'} print(child.tag, child.attrib) for node in child: print(node.tag, node.attrib, node.text) # 獲取到reank標簽

from xml.etree import ElementTree as ETcontent = '''<data> <country name='Liechtenstein'> <rank>2</rank> <year>2023</year> <gdppc>141100</gdppc> <neighbor direction='E' name='Austria' /> <neighbor direction='W' name='Switzerland' /> </country> <country name='Panama'> <rank>69</rank> <year>2026</year> <gdppc>13600</gdppc> <neighbor direction='W' name='Costa Rica' /> <neighbor direction='E' name='Colombia' /> </country></data>'''root = ET.XML(content)# 找到子子孫孫的year標簽for child in root.iter(’year’): print(child.tag, child.text)

from xml.etree import ElementTree as ETcontent = '''<data> <country name='Liechtenstein'> <rank>2</rank> <year>2023</year> <gdppc>141100</gdppc> <neighbor direction='E' name='Austria' /> <neighbor direction='W' name='Switzerland' /> </country> <country name='Panama'> <rank>69</rank> <year>2026</year> <gdppc>13600</gdppc> <neighbor direction='W' name='Costa Rica' /> <neighbor direction='E' name='Colombia' /> </country></data>'''root = ET.XML(content)v1 = root.findall(’country’) # 找到所有的country標簽print(v1)v2 = root.find(’country’).find(’rank’) # 找到country標簽中的rank標簽print(v2.text)

刪除和修改節(jié)點

from xml.etree import ElementTree as ETcontent = '''<data> <country name='Liechtenstein'> <rank>2</rank> <year>2023</year> <gdppc>141100</gdppc> <neighbor direction='E' name='Austria' /> <neighbor direction='W' name='Switzerland' /> </country> <country name='Panama'> <rank>69</rank> <year>2026</year> <gdppc>13600</gdppc> <neighbor direction='W' name='Costa Rica' /> <neighbor direction='E' name='Colombia' /> </country></data>'''root = ET.XML(content)# 修改節(jié)點內(nèi)容和屬性rank = root.find(’country’).find(’rank’)print(rank.text)rank.text = '999' # 修改rank標簽里面的內(nèi)容rank.set(’update’, ’2020-11-11’) # 為rank標簽新增一個update屬性print(rank.text, rank.attrib)############ 保存文件 ############tree = ET.ElementTree(root)tree.write('new.xml', encoding=’utf-8’)# 刪除節(jié)點root.remove( root.find(’country’) )print(root.findall(’country’))############ 保存文件 ############tree = ET.ElementTree(root)tree.write('newnew.xml', encoding=’utf-8’)

構(gòu)建文檔

<home> <son name='兒1'> <grandson name='兒11'></grandson> <grandson name='兒12'></grandson> </son> <son name='兒2'></son></home>

from xml.etree import ElementTree as ET# 創(chuàng)建根標簽root = ET.Element('home')# 創(chuàng)建節(jié)點大兒子son1 = ET.Element(’son’, {’name’: ’兒1’})# 創(chuàng)建小兒子son2 = ET.Element(’son’, {'name': ’兒2’})# 在大兒子中創(chuàng)建兩個孫子grandson1 = ET.Element(’grandson’, {’name’: ’兒11’})grandson2 = ET.Element(’grandson’, {’name’: ’兒12’})son1.append(grandson1)son1.append(grandson2)# 把兒子添加到根節(jié)點中root.append(son1)root.append(son2)tree = ET.ElementTree(root)tree.write(’oooo.xml’, encoding=’utf-8’, short_empty_elements=False) #short_empty_elements 是否采取短標簽的形式創(chuàng)建

<famliy> <son name='兒1'> <grandson name='兒11'></grandson> <grandson name='兒12'></grandson> </son> <son name='兒2'></son></famliy>

from xml.etree import ElementTree as ET# 創(chuàng)建根節(jié)點root = ET.Element('famliy')# 創(chuàng)建大兒子son1 = root.makeelement(’son’, {’name’: ’兒1’})# 創(chuàng)建小兒子son2 = root.makeelement(’son’, {'name': ’兒2’})# 在大兒子中創(chuàng)建兩個孫子grandson1 = son1.makeelement(’grandson’, {’name’: ’兒11’})grandson2 = son1.makeelement(’grandson’, {’name’: ’兒12’})son1.append(grandson1)son1.append(grandson2)# 把兒子添加到根節(jié)點中root.append(son1)root.append(son2)tree = ET.ElementTree(root)tree.write(’oooo.xml’,encoding=’utf-8’)

<famliy><son name='兒1'> <age name='兒11'>孫子</age> </son><son name='兒2'></son></famliy>

from xml.etree import ElementTree as ET# 創(chuàng)建根節(jié)點root = ET.Element('famliy')# 創(chuàng)建節(jié)點大兒子son1 = ET.SubElement(root, 'son', attrib={’name’: ’兒1’})# 創(chuàng)建小兒子son2 = ET.SubElement(root, 'son', attrib={'name': '兒2'})# 在大兒子中創(chuàng)建一個孫子grandson1 = ET.SubElement(son1, 'age', attrib={’name’: ’兒11’})grandson1.text = ’孫子’et = ET.ElementTree(root) #生成文檔對象et.write('test.xml', encoding='utf-8')

<user><![CDATA[你好呀]]</user>

from xml.etree import ElementTree as ET# 創(chuàng)建根節(jié)點root = ET.Element('user')root.text = '<![CDATA[你好呀]]'et = ET.ElementTree(root) # 生成文檔對象et.write('test.xml', encoding='utf-8')

到此這篇關(guān)于基于Python的XML格式的文件的文章就介紹到這了,更多相關(guān)python xml格式文件內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 久草在线视频网站 | 免费一级视频在线播放 | 欧美特级特黄a大片免费 | 国产精品欧美亚洲韩国日本不卡 | 国产毛片基地 | 亚洲精品日韩专区在线观看 | 寡妇一级a毛片免费播放 | 国产精品久久久久亚洲 | 国产男女猛烈无遮档免费视频网站 | 国产第一亚洲 | 欧美精品成人一区二区视频一 | 日韩专区在线 | 欧美人成人亚洲专区中文字幕 | 韩国啪啪网站 | 日韩毛片高清免费 | 88av视频在线 | 国产成人亚洲综合一区 | 国产精品国产自线在线观看 | 白嫩美女直冒白浆 | 男人的天堂在线观看入口 | 72种姿势欧美久久久久大黄蕉 | 精品国产一二三区 | 日韩一级片免费在线观看 | 免费国产成人手机在线观看 | 日韩精品在线播放 | 亚洲一区免费观看 | 国产精品成人观看视频免费 | 欧美一级黄色毛片 | 欧美日韩在线看 | 成人三级在线播放线观看 | 九九精品视频一区二区三区 | 国内精品久久久久久久星辰影视 | 国产欧美成人一区二区三区 | 美女扒开双腿让男人桶 | 日韩欧美在线一区二区三区 | 日韩一区二区不卡中文字幕 | 久久精品国产亚洲高清 | 久久精品人人爽人人爽快 | 偷拍自拍第一页 | 亚洲综合色一区二区三区另类 | 毛片免费在线 |