Python xmltodict模塊安裝及代碼實(shí)例
最近在對(duì)接微信公眾號(hào)、微信支付等功能,發(fā)現(xiàn)很多都是用xml格式的。在使用django日常處理的時(shí)候,都是手動(dòng)拼接的,真的是很惡心。今天仔細(xì)的看了一下python的xmltodict模塊,發(fā)現(xiàn)其實(shí)完全可以不用手動(dòng)拼接,輪子本身都有了。只要那來(lái)用就好了。之前自己的方式反而有點(diǎn)傻逼了。
首先使用和安裝都很簡(jiǎn)單
安裝
pip install xmltodict #如果安裝失敗,直接去github上下載手動(dòng)裝吧,https://github.com/martinblech/xmltodict
從名字就知道了 他是一個(gè)支持從xml轉(zhuǎn)換到python的dict互相轉(zhuǎn)換的模塊。(真的很方便)
dict轉(zhuǎn)換xml(用的比較多)
這個(gè)的使用場(chǎng)景是真的多,比如微信支付各種信息獲取都需要用到。
xmltodict.unparse()方法可以方便的將字典轉(zhuǎn)換為xml字符串。
import xmltodictd = {’xml’:{’a’: ’123’,’b’: ’234’}}xml_tmp = xmltodict.unparse(d)print(xml_tmp)--><?xml version='1.0' encoding='utf-8'?><xml><a>123</a><b>234</b></xml>
看著上面的字典格式也有點(diǎn)奇怪,這里要說(shuō)明一下,生成xml只能只有一個(gè)根,否則會(huì)報(bào)錯(cuò)ValueError: Document must have exactly one root.
解決方式也比較簡(jiǎn)單,只要將你需要的字典內(nèi)容在嵌套到一個(gè)xml的鍵里面,保證字典的第一層只有xml這個(gè)鍵即可。
xml轉(zhuǎn)換dict
這個(gè)方法用的不多,我目前主要是用在處理回調(diào)解析微信傳給我們的xml數(shù)據(jù)。
xmltodict.parse()將xml轉(zhuǎn)換為字典。
接著上面的例子,繼續(xù)往下吧。
import xmltodictd = {’xml’:{’a’: ’123’,’b’: ’234’}}xml_tmp = xmltodict.unparse(d)print(xml_tmp)#將轉(zhuǎn)換的xml在轉(zhuǎn)換回字典dt = xmltodict.parse(xml_tmp)print(dt,type(dt))--> OrderedDict([(’xml’, OrderedDict([(’a’, ’123’), (’b’, ’234’)]))]) <class ’collections.OrderedDict’>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. chat.asp聊天程序的編寫方法2. jsp EL表達(dá)式詳解3. Django程序的優(yōu)化技巧4. XML入門的常見(jiàn)問(wèn)題(一)5. Python多線程操作之互斥鎖、遞歸鎖、信號(hào)量、事件實(shí)例詳解6. IntelliJ IDEA 統(tǒng)一設(shè)置編碼為utf-8編碼的實(shí)現(xiàn)7. Django ORM實(shí)現(xiàn)按天獲取數(shù)據(jù)去重求和例子8. Jsp中request的3個(gè)基礎(chǔ)實(shí)踐9. idea設(shè)置自動(dòng)導(dǎo)入依賴的方法步驟10. 怎樣才能用js生成xmldom對(duì)象,并且在firefox中也實(shí)現(xiàn)xml數(shù)據(jù)島?
