亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

python中xml格式的轉(zhuǎn)換方法

 更新時(shí)間:2022年08月09日 14:26:07   作者:開心+1  
這篇文章主要為大家詳細(xì)介紹了python中xml格式的轉(zhuǎn)換方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

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)文章

最新評(píng)論