利用 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è)置和移除密碼
在數(shù)字化時代,文檔的安全性變得越來越重要,特別是對于包含敏感信息的PDF文件,所以本文主要來和大家介紹一下如何使用Python實現(xiàn)為PDF文檔設(shè)置和移除密碼,需要的可以參考下2024-03-03夯實基礎(chǔ)python集合的應(yīng)用場景及字符串定義和表示
這篇文章主要為大家介紹了python集合的應(yīng)用場景及字符串定義和表示,來幫大家夯實基礎(chǔ),有需要的朋友可以借鑒參考下,希望能夠有所幫助2023-10-10利用Python3分析sitemap.xml并抓取導(dǎo)出全站鏈接詳解
因為最近更換了網(wǎng)址,所以需要在百度站長平臺提交網(wǎng)址,不管是主動推送還是手動提交,前提都是要整理網(wǎng)站的鏈接,手動添加太麻煩,于是就想寫個腳本直接抓取全站鏈接并導(dǎo)出,本文詳細(xì)介紹的是實現(xiàn)的方法及過程,需要的朋友們一起來看看吧。2017-07-07Python調(diào)用百度根據(jù)經(jīng)緯度查詢地址的示例代碼
今天小編就為大家分享一篇Python調(diào)用百度根據(jù)經(jīng)緯度查詢地址的示例代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-07-07Python使用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