中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么用python標準庫ElementTree處理xml

發布時間:2022-05-20 14:23:51 來源:億速云 閱讀:237 作者:iii 欄目:開發技術

本篇內容介紹了“怎么用python標準庫ElementTree處理xml”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

1. 示例用法

參照官方文檔,創建country_data.xml測試文檔,內容如下:

<?xml version="1.0"?>
<data>
    <country name="Liechtenstein">
        <rank>1</rank>
        <year>2008</year>
        <gdppc>141100</gdppc>
        <neighbor name="Austria" direction="E"/>
        <neighbor name="Switzerland" direction="W"/>
    </country>
    <country name="Singapore">
        <rank>4</rank>
        <year>2011</year>
        <gdppc>59900</gdppc>
        <neighbor name="Malaysia" direction="N"/>
    </country>
    <country name="Panama">
        <rank>68</rank>
        <year>2011</year>
        <gdppc>13600</gdppc>
        <neighbor name="Costa Rica" direction="W"/>
        <neighbor name="Colombia" direction="E"/>
    </country>
</data>

使用如下代碼,將數據讀出,打印

from xml.etree.ElementTree 
data = ElementTree.ElementTree(file='country_data.xml')
country_list = data.findall('country')   #找到所有名為‘country'的tag,返回一個Element對象列表。
for country in country_list:
    name = country.attrib.get('name', '') 
    print name, ' ', 
    for item in country:
        if item.tag == 'neighbor':
            name = item.attrib.get('name', '') 
            direction = item.attrib.get('direction', '') 
            print '{0} ({1})'.format(name, direction), ' ',
        else:
            print item.text, ' ',
    print ''

其中

data = ElementTree.ElementTree(file='country_data.xml')

獲得一個ElementTree對象,也可以使用

tree = ElementTree.parse('country_data.xml')

Element對象具有如下屬性和操作

elem.tag這個Element對象的名字(tag)
elem.text文檔內容
elem.attrib屬性值字典
elem.tail與屬性一起存儲的其他數據

elem[n] 返回elem的第n個子元素

elem[n] = new_elem 將elem的第n個子元素更改為不同的元素new_elem

del elem[n] 刪除子元素

len(elem) 子元素的數量

elem.find(path)

elem.getchildren() 按文檔順序返回所有子元素

elem.items()將所有元素的屬性值以(name, value)對列表形式返回

遇到非法格式的xml

ExpatError: no element found

bad.xml為空文檔時,內容如下:

<?xml version="1.0"?>

執行如下python代碼,遇到xml.parser.expat.ExpatError異常:

import xml.etree.ElementTree as ET
ET.parse('bad.xml')

xml.parsers.expat.ExpatError: no element found: line 3, column 0

ExpatError: mismatched tag

bad.xml中找不到對應結束標記符時,內容如下:

<?xml version="1.0"?>
<note>
</Note>

因為區分大小寫,所以</Note> 不能作為<note>的結束標記。

xml.parsers.expat.ExpatError: mismatched tag: line 3, column 2

ExpatError: not well-formed(invalid token)

bad.xml中屬性值未包含在雙引號(&quot;)之中時,遇到如下異常:

<?xml version="1.0"?>
<note id=hello>
</note>

bad.xml中非法符號,在"if salary < 1000 then"語句的&lsquo;<',如下:

<?xml version="1.0"?>
<note id="hello">
if salary < 1000 then
</note

xml.parsers.expat.ExpatError: not well-formed (invalid token): line 2, column 9

“怎么用python標準庫ElementTree處理xml”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

尚志市| 蒙城县| 芮城县| 西和县| 嘉定区| 铜山县| 襄垣县| 宝坻区| 荣成市| 宣化县| 临海市| 科尔| 三门峡市| 长宁区| 涪陵区| 三门县| 孟津县| 灵台县| 晋州市| 龙江县| 鹰潭市| 新安县| 镇雄县| 定结县| 新津县| 江安县| 仙桃市| 南昌县| 阿拉善左旗| 法库县| 嘉义市| 楚雄市| 苍山县| 阿克| 祁东县| 乌兰浩特市| 北安市| 昌宁县| 茶陵县| 辛集市| 莱芜市|