欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python中xml.etree.ElementTree的使用示例

 更新時間:2024年09月20日 11:32:10   作者:pumpkin84514  
ElementTree是Python標準庫中的一個模塊,專門用于處理XML文件,它提供了解析、創(chuàng)建、修改和遍歷XML文檔的API,非常適合處理配置文件、數(shù)據(jù)交換格式和Web服務響應等場景,本文就來介紹一下,感興趣的可以了解一下

xml.etree.ElementTree(簡稱ElementTree)是Python標準庫中用于處理XML文件的模塊。它提供了簡潔且高效的API,適用于解析、創(chuàng)建和修改XML文檔。在需要處理XML數(shù)據(jù)的場景中,比如配置文件、數(shù)據(jù)交換格式、Web服務響應等,ElementTree都是非常實用的工具。

一、基本使用場景

  • 解析XML文檔:讀取并解析XML文檔,將其轉換為樹結構以便進一步操作。
  • 創(chuàng)建XML文檔:從頭開始構建XML文檔,并將其保存到文件中。
  • 修改XML文檔:在解析后的XML樹中添加、刪除或修改元素。
  • 搜索與遍歷XML樹:查找特定的元素或屬性,遍歷整個XML樹結構。

二、核心API與用法

1. 解析XML文檔

解析字符串形式的XML:

import xml.etree.ElementTree as ET

xml_data = '''<data>
    <user>
        <name>John</name>
        <age>30</age>
    </user>
</data>'''

root = ET.fromstring(xml_data)
print(root.tag)

輸出:

data

解析XML文件:

import xml.etree.ElementTree as ET

tree = ET.parse('example.xml')
root = tree.getroot()
print(root.tag)

輸出:

data

2. 創(chuàng)建XML文檔

import xml.etree.ElementTree as ET

# 創(chuàng)建根元素
root = ET.Element('data')

# 創(chuàng)建子元素
user = ET.SubElement(root, 'user')
name = ET.SubElement(user, 'name')
name.text = 'John'
age = ET.SubElement(user, 'age')
age.text = '30'

# 將XML樹寫入文件
tree = ET.ElementTree(root)
tree.write('output.xml', encoding='utf-8', xml_declaration=True)

生成的output.xml內(nèi)容:

<?xml version='1.0' encoding='utf-8'?>
<data>
    <user>
        <name>John</name>
        <age>30</age>
    </user>
</data>

3. 修改XML文檔

修改現(xiàn)有元素的文本內(nèi)容:

import xml.etree.ElementTree as ET

tree = ET.parse('output.xml')
root = tree.getroot()

# 修改元素內(nèi)容
root.find('user/name').text = 'Jane'

tree.write('output_modified.xml', encoding='utf-8', xml_declaration=True)

output_modified.xml內(nèi)容:

<?xml version='1.0' encoding='utf-8'?>
<data>
    <user>
        <name>Jane</name>
        <age>30</age>
    </user>
</data>

4. 搜索與遍歷XML樹

遍歷所有子元素:

import xml.etree.ElementTree as ET

tree = ET.parse('output.xml')
root = tree.getroot()

for child in root.iter():
    print(child.tag, child.text)

輸出:

data None
user None
name John
age 30

查找特定元素:

import xml.etree.ElementTree as ET

tree = ET.parse('output.xml')
root = tree.getroot()

name = root.find('user/name')
print(name.text)

輸出:

John

三、進階用法

1. 處理帶有命名空間的XML

命名空間在復雜XML文檔中非常常見,用于區(qū)分不同元素的作用域。

解析帶有命名空間的XML:

import xml.etree.ElementTree as ET

xml_data = '''<root xmlns:h="http://www.w3.org/TR/html4/" xmlns:f="http://www.w3schools.com/furniture">
    <h:table>
        <h:tr>
            <h:td>Apples</h:td>
            <h:td>Bananas</h:td>
        </h:tr>
    </h:table>
    <f:table>
        <f:name>African Coffee Table</f:name>
        <f:width>80</f:width>
        <f:length>120</f:length>
    </f:table>
</root>'''

root = ET.fromstring(xml_data)

# 使用命名空間解析
for table in root.findall('{http://www.w3.org/TR/html4/}table'):
    for td in table.findall('{http://www.w3.org/TR/html4/}td'):
        print(td.text)

輸出:

Apples
Bananas

2. 使用XPath查找元素

雖然ElementTree本身不支持完整的XPath語法,但提供了類似的路徑查找功能。

import xml.etree.ElementTree as ET

xml_data = '''<root>
    <users>
        <user id="1">
            <name>John</name>
        </user>
        <user id="2">
            <name>Jane</name>
        </user>
    </users>
</root>'''

root = ET.fromstring(xml_data)

# 查找id為2的用戶的名稱
name = root.find('.//user[@id="2"]/name').text
print(name)

輸出:

Jane

3. 批量處理和轉換XML

當需要處理大量的XML數(shù)據(jù)時,可以利用生成器或者批量處理方法來提高效率。

import xml.etree.ElementTree as ET

def parse_large_xml(file):
    context = ET.iterparse(file, events=('start', 'end'))
    for event, elem in context:
        if event == 'end' and elem.tag == 'user':
            yield elem
            elem.clear()  # 清除元素以節(jié)省內(nèi)存

for user in parse_large_xml('large_users.xml'):
    print(user.find('name').text)

四、常用技巧

1. 使用生成器高效解析大文件

如上所述,使用iterparse()和生成器可以有效節(jié)省內(nèi)存并提高處理速度,適用于大文件的解析。

2. 自動縮進與格式化輸出

默認情況下,ElementTree生成的XML是無縮進的,可以通過手動調整生成XML的格式來使其更具可讀性。

import xml.etree.ElementTree as ET

def indent(elem, level=0):
    i = "\n" + level*"  "
    if len(elem):
        if not elem.text or not elem.text.strip():
            elem.text = i + "  "
        if not elem.tail or not elem.tail.strip():
            elem.tail = i
        for subelem in elem:
            indent(subelem, level+1)
        if not elem.tail or not elem.tail.strip():
            elem.tail = i
    else:
        if level and (not elem.tail or not elem.tail.strip()):
            elem.tail = i

root = ET.Element("root")
child = ET.SubElement(root, "child")
indent(root)
tree = ET.ElementTree(root)
tree.write("output_pretty.xml", encoding="utf-8", xml_declaration=True)

生成的output_pretty.xml內(nèi)容:

<?xml version='1.0' encoding='utf-8'?>
<root>
  <child />
</root>

3. 安全處理外部實體

在處理來自不受信任源的XML數(shù)據(jù)時,最好禁用外部實體,以防止XML外部實體注入(XXE)攻擊。

import xml.etree.ElementTree as ET
from defusedxml.ElementTree import parse, fromstring

# 安全地解析XML
tree = parse('example.xml')
root = tree.getroot()

# 或者
root = fromstring(xml_data)

defusedxml庫提供了更安全的XML解析方法,防止常見的安全漏洞。

到此這篇關于Python中xml.etree.ElementTree的使用示例的文章就介紹到這了,更多相關Python xml.etree.ElementTree內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 忘記ftp密碼的解決方法示例

    忘記ftp密碼的解決方法示例

    忘記ftp密碼了怎么辦?下面介紹一個使用python ftplib庫的方法,大家參考使用吧
    2014-01-01
  • Python中pygame安裝方法圖文詳解

    Python中pygame安裝方法圖文詳解

    這篇文章主要介紹了Python中pygame安裝方法,結合圖文說明,較為詳細的分析總結了Python中pygame的下載及安裝調試詳細步驟,需要的朋友可以參考下
    2015-11-11
  • python提取xml里面的鏈接源碼詳解

    python提取xml里面的鏈接源碼詳解

    在本篇文章里小編給大家整理的是關于python提取xml里面的鏈接的相關知識點內(nèi)容,需要的朋友們可以學習下。
    2019-10-10
  • Python+opencv 實現(xiàn)圖片文字的分割的方法示例

    Python+opencv 實現(xiàn)圖片文字的分割的方法示例

    這篇文章主要介紹了Python+opencv 實現(xiàn)圖片文字的分割的方法示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-07-07
  • Python使用PyPDF2和ReportLab操作PDF文件的詳細指南

    Python使用PyPDF2和ReportLab操作PDF文件的詳細指南

    在日常工作和項目中,PDF 文件處理是個常見需求,不論是合并報告、加密文檔、填充表單,還是生成發(fā)票,Python 中有許多用于操作 PDF 文件的庫,其中 PyPDF2 和 ReportLab 是兩個廣泛使用的工具,本文給大家介紹了Python使用PyPDF2和ReportLab操作PDF文件的詳細指南
    2025-01-01
  • 解決python ogr shp字段寫入中文亂碼的問題

    解決python ogr shp字段寫入中文亂碼的問題

    今天小編就為大家分享一篇解決python ogr shp字段寫入中文亂碼的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-12-12
  • Python登錄系統(tǒng)界面實現(xiàn)詳解

    Python登錄系統(tǒng)界面實現(xiàn)詳解

    這篇文章主要介紹了Python登錄系統(tǒng)界面實現(xiàn)詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,,需要的朋友可以參考下
    2019-06-06
  • Python如何在終端彩色打印輸出

    Python如何在終端彩色打印輸出

    大家好,本篇文章主要講的是Python如何在終端彩色打印輸出,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-02-02
  • 用Python解析XML的幾種常見方法的介紹

    用Python解析XML的幾種常見方法的介紹

    這篇文章主要介紹了用Python解析XML的幾種常見方法,包括快速的使用ElementTree模塊等方法的實例介紹,需要的朋友可以參考下
    2015-04-04
  • Python列出一個文件夾及其子目錄的所有文件

    Python列出一個文件夾及其子目錄的所有文件

    這篇文章主要介紹了Python列出一個文件夾及其子目錄的所有文件的方法,和python列出文件夾下的所有文件的四種方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-06-06

最新評論