亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

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

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

瀏覽:4日期: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)文章:
主站蜘蛛池模板: 成人综合婷婷国产精品久久免费 | 日本黄视频在线观看 | 欧美日韩亚洲另类人人澡 | 国产一级生活片 | 国产成人综合视频 | 精品综合久久久久久8888 | 精品美女在线 | 国产欧美成人xxx视频 | 国产乱码一区二区三区四 | 免费一级特黄 欧美大片 | 日韩小视频在线播放 | 国产v精品成人免费视频71sao | 成人污视频在线观看 | 久久99精品视频在线在线观看 | 无遮挡1000部拍拍拍免费 | 一级毛片在线全部免费播放 | 国产你懂得 | 真正国产乱子伦高清对白 | 在线免费观看网站入口在哪 | 日韩高清不卡在线 | 午夜精品成人毛片 | a免费国产一级特黄aa大 | 日本高清视频www夜色资源 | 国产一级毛片外aaaa | 一级全免费视频播放 | 曰批全过程免费动态图 | 一级做a爰片欧美aaaa | 久久国产精品视频一区 | 一级毛片特级毛片黄毛片 | 亚洲高清免费观看 | 91精品国产自产91精品 | 色综合久久精品中文字幕 | 曰韩美女一级视频 | 亚洲美女一级毛片 | 亚洲一区二区三区播放在线 | 欧美屁屁影院 | 亚洲欧美一区二区三区久本道 | 久草在线资源福利站 | 日本无翼乌邪恶大全彩h污污 | 久久精品国产亚洲网站 | 伊人中文字幕在线 |