python中xml格式的轉(zhuǎn)換方法
python中xml格式的轉(zhuǎn)換,供大家參考,具體內(nèi)容如下
近期在做項(xiàng)目的時(shí)候需要將數(shù)據(jù)進(jìn)行xml和dict 的轉(zhuǎn)換,這里進(jìn)行初步的總結(jié)
1. 基于DOM.
寫入
# 導(dǎo)入 import xml.dom.minidom as minidom # 創(chuàng)建文檔實(shí)例 dom = minidom.getDOMImplementation().createDocument(None,'Root',None) # 獲得根節(jié)點(diǎn) root = dom.documentElement for i in range(5): ? ? # 創(chuàng)建節(jié)點(diǎn) ? ? element = dom.createElement('Name') ? ? # 給這個(gè)節(jié)點(diǎn)添加數(shù)據(jù) ? ? element.appendChild(dom.createTextNode('default')) ? ? # 設(shè)置屬性 ? ? element.setAttribute('age', str(i)) ? ? # 添加到節(jié)點(diǎn) ? ? root.appendChild(element) # 保存文件 ?相對(duì)與原始的寫入回自動(dòng)縮進(jìn) with open('own.xml', 'w', encoding='utf-8') as f: ? ? dom.writexml(f, addindent='\t', newl='\n',encoding='utf-8') # 文檔內(nèi)容 <?xml version="1.0" encoding="utf-8"?> <Root> ? ? <Name age="0">default</Name> ? ? <Name age="1">default</Name> ? ? <Name age="2">default</Name> ? ? <Name age="3">default</Name> ? ? <Name age="4">default</Name> </Root> # ================================== 如果需要將已經(jīng)寫好的xml文件進(jìn)行縮進(jìn)處理 可以執(zhí)行以下代碼 ?root 是獲取的根節(jié)點(diǎn) import xml.etree.ElementTree as ET from xml.dom import minidom def save_xml(root, filename, indent="\t", newl="\n", encoding="utf-8"): ?? ?raw_text = ET.tostring(root) ? ? dom = minidom.parseString(raw_Text) ? ? with open(filename, "w") as f: ? ? ? ? dom.writexml(f, indent, newl, encoding) ?
讀取
import xml.etree.ElementTree as ET from xml.dom import minidom # 讀取文檔 dom = minidom.parse("own.xml") # 獲取根節(jié)點(diǎn) root = dom.documentElement # 按照名稱查找字節(jié)點(diǎn), 注意這里 回遞歸查找所有子節(jié)點(diǎn) ?所有的子節(jié)點(diǎn): root.childNodes names = root.getElementsByTagName("Name") for name in names: ? ?? ? ? print(name.childNodes[0].nodeValue, end="\t") ? ? # 查詢name是否含有屬性age ? ? if name.hasAttribute("age"): ? ? ? ? # 產(chǎn)看屬性age ? ? ? ? print(name.getAttribute("age"), end="\t") ? ? print("")
2. 基于ElementTree
寫入
# 導(dǎo)入? # -*- coding:utf-8 -*- import xml.etree.ElementTree as ET # 增加換行符 def __indent(elem, level=0): ? ? i = "\n" + level*"\t" ? ? if len(elem): ? ? ? ? if not elem.text or not elem.text.strip(): ? ? ? ? ? ? elem.text = i + "\t" ? ? ? ? if not elem.tail or not elem.tail.strip(): ? ? ? ? ? ? elem.tail = i ? ? ? ? for elem in elem: ? ? ? ? ? ? __indent(elem, 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') ? ? ? # 創(chuàng)建節(jié)點(diǎn) tree = ET.ElementTree(root) ? ? # 創(chuàng)建文檔 for i in range(5): ? ? element = ET.Element('Name') ? ? element.set('age', str(i)) ? ? element.text = 'default' ? ? root.append(element) __indent(root) ? ? ? ? ?# 增加換行符 tree.write('default.xml', encoding='utf-8', xml_declaration=True) # 文檔內(nèi)容 <?xml version='1.0' encoding='utf-8'?> <Root> ? ? <Name age="0">default</Name> ? ? <Name age="1">default</Name> ? ? <Name age="2">default</Name> ? ? <Name age="3">default</Name> ? ? <Name age="4">default</Name> </Root>
讀取
# -*- coding:utf-8 -*- import xml.etree.ElementTree as ET # 獲取文檔 tree = ET.parse('default.xml') # 獲取根節(jié)點(diǎn) root = tree.getroot() # 獲取所有子節(jié)點(diǎn) list(root) ? # 查找所有子節(jié)點(diǎn)(非遞歸) root.findall("Name") ?遞歸 root.iter("Name") for node in list(root): ? ? print(node.text, node.tag, node.get('age')) for node in root.findall('Name'): ? ? print(node.text, node.tag, node.get('age')) # 輸出 default Name 0 default Name 1 default Name 2 default Name 3 default Name 4 default Name 0 default Name 1 default Name 2 default Name 3 default Name 4
使用dicttoxml xmltodict等模塊
1、解析xml文件:
使用iterfind尋找節(jié)點(diǎn),獲取子節(jié)點(diǎn)方法 list(節(jié)點(diǎn)),獲取節(jié)點(diǎn)屬性 get(屬性名),下一級(jí)節(jié)點(diǎn)的值findtext
from xml.etree.ElementTree import parse try: ? doc=parse('b.xml') ? for item in doc.iterfind('class'): ? ? ? classname=item.get('a_name') ? ? ? print("classname=",classname) ? ? ? for s in list(item): ? ? ? ? name=s.findtext('name') ? ? ? ? age = s.findtext('age') ? ? ? ? sex = s.findtext('sex') ? ? ? ? print("name=",name,"age=",age,"sex=",sex) ? ? ? print("-------------------") except Exception as e: ? print(e)
2、字典轉(zhuǎn)換為xml文件:
使用dicttoxml模塊,方法:dicttoxml.dicttoxml(字典數(shù)據(jù),根節(jié)點(diǎn)名稱 custom_root=”)import dicttoxml
from xml.dom.minidom import parseString import os d=[20,'name', ? {'name':'apple','num':10,'price':23}, ? {'name': 'pear', 'num': 20, 'price': 18.7}, ? {'name': 'banana', 'num': 10.5, 'price': 23}] bxml=dicttoxml.dicttoxml(d,custom_root='fruit') xml=bxml.decode('utf-8') print(xml) dom=parseString(xml) pxml=dom.toprettyxml(indent=' ?') f=open('fruits.xml','w',encoding='utf-8') f.write(pxml) f.close()
3、xml文件轉(zhuǎn)為字典:
使用xmltodict模塊 ,方法:xmltodict.parse(xml字符串)
import xmltodict import pprint f=open('fruits.xml') xml=f.read() d=xmltodict.parse(xml) pp=pprint.PrettyPrinter(indent=4) pp.pprint(d)#可以通過(guò)d['root']['arg']['#text']來(lái)訪問(wèn)節(jié)點(diǎn)中的文本值,d['root']['arg']['@p']來(lái)訪問(wèn)屬性值 f.close()
4、字典轉(zhuǎn)換為json
使用json的dumps方法
import json data={'name':'bill','company':'huawei','age':30} jsonstr=json.dumps(data) print(jsonstr)
5、json轉(zhuǎn)換為字典:
使用json模塊的loads函數(shù),傳入json字符串,返回該字符串對(duì)應(yīng)的字典
d=json.loads(jsonstr) print(d)
6、json轉(zhuǎn)換為類實(shí)例
1)、在指定的類中必須有一個(gè)接受字典的構(gòu)造函數(shù);或指定回調(diào)函數(shù)json2Product;
2)、使用json的loads方法(json字符串,object_hook=類名或者回調(diào)函數(shù)名)
import json class Product: ? def __init__(self,d): ? ? self.__dict__=d def json2Product(d): ? return Product(d) f=open('products.json','r',encoding='utf-8') strjson=f.read() products=json.loads(strjson,object_hook=Product) for p in products: ? print('name=',p.name,'price=',p.price)
7、 類實(shí)例轉(zhuǎn)換為json:
1)、指定回調(diào)函數(shù)(product2Dict)
2)、使用json的dump函數(shù),指定default參數(shù)的回調(diào)函數(shù)import json
def product2Dict(product): ? return { ? ? 'name': product.name, ? ? 'price': product.price, ? ? 'count': product.count ? ? } strJson=json.dumps(products,default=product2Dict) print(strJson)
8、字典轉(zhuǎn)換為類:
1)、將字典轉(zhuǎn)換為json
2)、json轉(zhuǎn)換為類
import json data=[{"name": "iPhone9", "price": 9999, "count": 3000}, {"name": "tesila", "price": 800000, "count": 122}] # 將字典轉(zhuǎn)換為json jsonstr=json.dumps(data) class Product: ? def __init__(self,d): ? ? self.__dict__=d def json2Product(d): ? return Product(d) # 將json轉(zhuǎn)換為類 ps=json.loads(jsonstr,object_hook=Product) for p in ps: ? print('name=', p.name, 'price=', p.price)
9、將類轉(zhuǎn)換為字典:
1)、類轉(zhuǎn)換為json,使用json的dumps方法
2)、json轉(zhuǎn)為字典,使用json的loads方法
def product2Dict(product): ? return { ? ? 'name': product.name, ? ? 'price': product.price, ? ? 'count': product.count ? ? } # 將類轉(zhuǎn)換為json strJson=json.dumps(ps,default=product2Dict) print(strJson) d=json.loads(strJson) print(d)
10、json轉(zhuǎn)xml
1)、先將xml轉(zhuǎn)換為字典
2)、再使用dicttoxml轉(zhuǎn)換為字典
import json import dicttoxml f=open('products.json','r',encoding='utf-8') jsonstr=f.read() # 將json轉(zhuǎn)換為字典 d=json.loads(jsonstr) print(d) # 將字典轉(zhuǎn)換為xml bxml=dicttoxml.dicttoxml(d,custom_root='fruit') print(bxml)
11、將xml轉(zhuǎn)換為json
1)、先使用xmltodict轉(zhuǎn)換為字典
2)、再將字典轉(zhuǎn)換為json
import xmltodict import json f=open('products.xml','r',encoding='utf-8') d=f.read() #先將xml轉(zhuǎn)換為字典 data=xmltodict.parse(d) print(data) #再將字典轉(zhuǎn)換為json strjson=json.dumps(data) print(strjson)
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python神經(jīng)網(wǎng)絡(luò)Keras實(shí)現(xiàn)LSTM及其參數(shù)量詳解
這篇文章主要為大家介紹了python神經(jīng)網(wǎng)絡(luò)Keras實(shí)現(xiàn)LSTM及其參數(shù)量詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05python執(zhí)行等待程序直到第二天零點(diǎn)的方法
這篇文章主要介紹了python執(zhí)行等待程序直到第二天零點(diǎn)的方法,涉及Python等待程序的實(shí)現(xiàn)技巧,需要的朋友可以參考下2015-04-04關(guān)于Python的GPU編程實(shí)例近鄰表計(jì)算的講解
本文主要講解了Python的GPU編程實(shí)例近鄰表計(jì)算,通過(guò)一個(gè)近鄰表計(jì)算的案例,給出了適用于GPU加速的計(jì)算場(chǎng)景。需要了解的朋友可以參考一下這篇文章2021-08-08python socket網(wǎng)絡(luò)編程步驟詳解(socket套接字使用)
這篇文章主要介紹了什么是套接字、PYTHON套接字模塊,提供一個(gè)簡(jiǎn)單的python socket編程,大家參考使用2013-12-12