日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python中使用ElementTree 操作XML

發布時間:2025/3/20 python 12 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python中使用ElementTree 操作XML 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

概述


? ? ? 參考elementTree的官方文檔,ET 模塊可以歸納為三個部分:ElementTree類,Element類以及一些操作 XML 的函數。??XML是一種固有的分層數據格式,表示它的最自然的方式是使用樹。?ET為此目的有兩個類 -?ElementTree將整個XML文檔表示為樹,并?Element表示此樹中的單個節點。與整個文檔的交互(讀取和寫入文件)通常在ElementTree關卡上完成。與單個XML元素及其子元素的交互在該Element級別上完成。

XML中結點結構一般為:<tag attrib>text</tag>的形式

<tag attrib="attrib">text</tag>

1.解析XML文件

ET模塊支持從一個XML文件構造成一個ElementTree對象,以下以官方文檔中給出的country.xml為例進行接收

<?xml version="1.0" encoding="utf-8"?> <data><country1 name="Liechtenstein"><rank>1</rank><year>2008</year><gdppc>141100</gdppc><neighbor name="Austria" direction="E"/><neighbor name="Switzerland" direction="W"/></country1><country2 name="中國"><rank>68</rank><year>2011</year><gdppc>13600</gdppc><neighbor name="趙三" direction="西邊"/><neighbor name="李四" direction="東北"/></country2> </data>

使用ET模塊中的parse()函數構造一個ElementTree對象,如下所示:

#-*-encoding:utf-8-*-import xml.etree.ElementTree as ET# 獲取 XML 文檔對象 ElementTree tree = ET.parse('coutry.xml')# 獲取 XML 文檔對象的根結點 Element root = tree.getroot() # 打印根結點的名稱 print "tag:",root.tag

2.XML中查找結點信息

XML中可以使用三種方式進行查找,分別是find()findall()iter()的方式,下面通過實例進行介紹

1.find()方法和findall()

如果使用Element.findall()或者Element.find()方法,則只會從結點的直接子結點中查找,并不會遞歸查找。

for country in root.findall('country1'):rank = country.find('rank').textname = country.get('name')print name, rank

關于find()和findall()方法,可以參考一篇竊以為不錯的博客。

2.iter()

鑒于find()和findall()的缺點,自己較喜歡的使用iter()方法。

import xml.etree.ElementTree as ET# 獲取 XML 文檔對象 ElementTree tree = ET.parse('coutry.xml')# 獲取 XML 文檔對象的根結點 Element root = tree.getroot() #使用iter查找并打印結點信息 for index in root.iter("year2"):print "index.tag",index.tag

3.修改更新結點

結點的更新涉及到屬性更新,值的更新。如果更新屬性使用,修改Element.attrib進行修改;如果更新值使用Element.text更新,注意這里的值的更新,如果是數字類型,變化的時候需要需要先轉換成int,再轉換成str類型進行賦值。那更新后一般需要寫入原來的文件中,此時需要使用ElementTree.write()方法寫入到XML文件中,如下所示:

#-*- coding:utf-8 -*-import xml.etree.ElementTree as ET# 獲取 XML 文檔對象 ElementTree tree = ET.parse('coutry.xml')# 獲取 XML 文檔對象的根結點 Element root = tree.getroot()for index in root.iter("year2"):print "index.text", index.textindex.text = str(int(index.text) + 1)print "index.text", index.texttree.write("countryResult.xml",encoding="UTF-8")

?注意:這里編碼格式要使用“UTF-8”,如果使用的是"utf-8"保存后出現沒有頭部

<?xml version="1.0" encoding="utf-8"?>

的情況

總結

以上是生活随笔為你收集整理的python中使用ElementTree 操作XML的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 日本不卡一区在线观看 | 无人在线观看高清视频 单曲 | 欧美日韩乱国产 | 国模吧一区二区三区 | 黄色日批 | 日韩黄色高清视频 | 亚洲色图50p | 国产精品久久久久久久久夜色 | 91在线看视频| 精品国产一区二区视频 | 日韩无码精品一区二区三区 | av免费观看在线 | 国产一毛片 | 成人在线小视频 | 国产精品亚洲二区在线观看 | 一道本无吗一区 | 色噜噜色狠狠 | 国产在线一区二区三区 | 色婷婷综合在线 | 日本黄色一级 | 亚洲第一视频 | 日本一区二区三区免费观看 | 久久性色 | 欧美视频一区在线 | 久久久久黄 | 国产欧美熟妇另类久久久 | 波多野结衣调教 | 720url在线观看免费版 | 91av视频在线播放 | 亚洲在线综合 | 夜夜夜夜爽 | 初尝人妻少妇中文字幕 | 亚洲精品久久久久av无码 | 国产精品无码影院 | 亚洲国产果冻传媒av在线观看 | 五月婷婷丁香网 | 炕上如狼似虎的呻吟声 | 国产精品粉嫩 | 日日艹夜夜艹 | 性欧美成人播放77777 | 动漫涩涩免费网站在线看 | 翔田千里一区 | 中文字幕在线观看免费 | 一区二区在线视频播放 | 99爱视频| 免费一级淫片 | 国产妇女视频 | 天堂综合网 | 久久久久九九九九 | 免费看欧美大片 | 亚洲一卡二卡在线观看 | 美日韩一区二区 | 国产精品 色 | 夜夜撸影院 | 亚洲精品一区二三区 | 一区二区在线观看免费视频 | 久久久精品| 中文字幕久久一区 | 国产精品中文字幕在线观看 | 韩国精品视频在线观看 | 婷婷五月情 | 二级毛片在线观看 | 美女88av| 污网站免费在线观看 | 夜夜爽妓女8888视频免费观看 | 亚洲国产成人一区 | 亚洲天堂成人在线观看 | 欧美系列在线观看 | 伊人影片 | 国产精品成人国产乱一区 | 91欧美一区二区 | 国产精品 欧美精品 | 在线看片网站 | 欧美一级片在线观看 | 爱福利视频一区 | 日本在线一区二区三区 | 肥老熟妇伦子伦456视频 | 男女性生活视频网站 | 999视频在线 | 欧美情爱视频 | 亚洲在线观看一区二区 | 麻豆视频黄色 | 日本精品一区二区视频 | 亚洲天堂网址 | 色一五月 | 国产精品人人妻人人爽人人牛 | 亚洲天堂影院 | www视频在线 | 日韩欧美v | 熟妇人妻久久中文字幕 | 肥熟女一区二区三肥熟女 | 男人资源网站 | 国内自拍一区 | 美女尻逼视频 | 欧美午夜精品一区二区 | 免费看av毛片| 日韩黄色三级视频 | 在线你懂得 | 爱搞逼综合 |