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

利用 Python ElementTree 生成 xml的實例

 更新時間:2020年03月06日 12:56:07   作者:劍西樓  
這篇文章主要介紹了利用 Python ElementTree 生成 xml的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

Python 處理 xml 文檔的方法有很多,除了經(jīng)典的 sax 和 dom 之外,還有一個 ElementTree。

首先 import 之:

from xml.etree import ElementTree as etree

然后開始構(gòu)建 xml 樹:

from xml.etree.ElementTree import Element, SubElement, ElementTree
 
# 生成根節(jié)點(diǎn)
root = Element('root')
# 生成第一個子節(jié)點(diǎn) head
head = SubElement(root, 'head')
# head 節(jié)點(diǎn)的子節(jié)點(diǎn)
title = SubElement(head, 'title')
title.text = 'Well Dola!'
# 生成 root 的第二個子節(jié)點(diǎn) body
body = SubElement(root, 'body')
# body 的內(nèi)容
body.text = 'I love Dola!'
tree = ElementTree(root)

這樣就得到了一個 xml 樹的對象 tree 以及它的根節(jié)點(diǎn)的對象 root

接著我們把它們變成 xml 串,有兩個辦法,一個是用 tree 對象的 write 方法將 xml 內(nèi)容寫成一個文件,還有一個是用 etree 的 tostring 方法轉(zhuǎn)成 xml 字符串:

# 第一種
tree.write('result.xml', encoding='utf-8')
# 第二種
xml_string = etree.tostring(root)
# xml_string 就是 xml 字符串了

但是第二種有一個問題,就是它沒有

<?xml version="1.0"?>

這個頭部定義內(nèi)容:

'<root><head><title>Well Dola!</title></head><body>I love Dola!</body></root>'

怎么辦呢?

有一個辦法是使用 minidom 來實現(xiàn),方法如下:

from xml.dom import minidom
# 使用 minidom 解析
tree = minidom.parseString(xml_string)
# 重新生成 xml 字符串
xml_string = tree.toxml()

雖然讓計算機(jī)多運(yùn)行了一些代碼,但是這樣可以把問題解決掉。

最后生成的 xml 代碼如下:

u'<?xml version="1.0" ?><root><head><title>Well Dola!</title></head><body>I love Dola!</body></root>'

當(dāng)然還可以使用 minidom 中 tree 對象的 toprettyxml 方法把 xml 打得漂亮一點(diǎn)。

補(bǔ)充知識:Python ElementTree 導(dǎo)出 xml 缺少 開頭聲明

使用ElementTree修改完xml后,寫入文件時,發(fā)現(xiàn)開頭缺少了 <?xml version='1.0' encoding='utf-8'?>

解決辦法:

在調(diào)用ElementTree的write方法寫入xml時,參數(shù)里增加 encoding=‘utf-8' 以及 xml_declaration=True

et_root.write('file。xml', encoding='utf-8', xml_declaration=True)

以上這篇利用 Python ElementTree 生成 xml的實例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 使用Python實現(xiàn)為PDF文檔設(shè)置和移除密碼

    使用Python實現(xiàn)為PDF文檔設(shè)置和移除密碼

    在數(shù)字化時代,文檔的安全性變得越來越重要,特別是對于包含敏感信息的PDF文件,所以本文主要來和大家介紹一下如何使用Python實現(xiàn)為PDF文檔設(shè)置和移除密碼,需要的可以參考下
    2024-03-03
  • python-docx 頁面設(shè)置詳解

    python-docx 頁面設(shè)置詳解

    今天小編就為大家分享一篇python docx 中頁面的設(shè)置,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-10-10
  • python獲取文件擴(kuò)展名的方法

    python獲取文件擴(kuò)展名的方法

    這篇文章主要介紹了python獲取文件擴(kuò)展名的方法,涉及Python針對文件路徑的相關(guān)操作技巧,非常簡單實用,需要的朋友可以參考下
    2015-07-07
  • selenium?UI自動化實戰(zhàn)過程記錄

    selenium?UI自動化實戰(zhàn)過程記錄

    如果大家有做過web的自動化測試,相信對于selenium一定不陌生,測試人員經(jīng)常使用它來進(jìn)行自動化測試,下面這篇文章主要給大家介紹了關(guān)于selenium?UI自動化實戰(zhàn)的相關(guān)資料,需要的朋友可以參考下
    2021-12-12
  • 夯實基礎(chǔ)python集合的應(yīng)用場景及字符串定義和表示

    夯實基礎(chǔ)python集合的應(yīng)用場景及字符串定義和表示

    這篇文章主要為大家介紹了python集合的應(yīng)用場景及字符串定義和表示,來幫大家夯實基礎(chǔ),有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2023-10-10
  • python批量創(chuàng)建變量并賦值操作

    python批量創(chuàng)建變量并賦值操作

    這篇文章主要介紹了python批量創(chuàng)建變量并賦值操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • Python提取Word中圖片的實現(xiàn)步驟

    Python提取Word中圖片的實現(xiàn)步驟

    本文主要介紹了Python提取Word中圖片的實現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • 利用Python3分析sitemap.xml并抓取導(dǎo)出全站鏈接詳解

    利用Python3分析sitemap.xml并抓取導(dǎo)出全站鏈接詳解

    因為最近更換了網(wǎng)址,所以需要在百度站長平臺提交網(wǎng)址,不管是主動推送還是手動提交,前提都是要整理網(wǎng)站的鏈接,手動添加太麻煩,于是就想寫個腳本直接抓取全站鏈接并導(dǎo)出,本文詳細(xì)介紹的是實現(xiàn)的方法及過程,需要的朋友們一起來看看吧。
    2017-07-07
  • Python調(diào)用百度根據(jù)經(jīng)緯度查詢地址的示例代碼

    Python調(diào)用百度根據(jù)經(jīng)緯度查詢地址的示例代碼

    今天小編就為大家分享一篇Python調(diào)用百度根據(jù)經(jīng)緯度查詢地址的示例代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07
  • Python使用cx_Oracle模塊將oracle中數(shù)據(jù)導(dǎo)出到csv文件的方法

    Python使用cx_Oracle模塊將oracle中數(shù)據(jù)導(dǎo)出到csv文件的方法

    這篇文章主要介紹了Python使用cx_Oracle模塊將oracle中數(shù)據(jù)導(dǎo)出到csv文件的方法,涉及Python中cx_Oracle模塊與csv模塊操作Oracle數(shù)據(jù)庫及csv文件的相關(guān)技巧,需要的朋友可以參考下
    2015-05-05

最新評論