文章目录

  • python中xml格式的转换
    • 1. 基于DOM.
    • 2. 基于ElementTree
  • 使用dicttoxml xmltodict等模块
    • 1、解析xml文件:
    • 2、字典转换为xml文件:
    • 3、xml文件转为字典:
    • 4、字典转换为json
    • 5、json转换为字典:
    • 6、json转换为类实例,
    • 7、 类实例转换为json:
    • 8、字典转换为类:
    • 9、将类转换为字典:
    • 10、json转xml
    • 11、将xml转换为json

python中xml格式的转换

近期在做项目的时候需要将数据进行xml和dict 的转换,这里进行初步的总结

1. 基于DOM.

写入

# 导入
import xml.dom.minidom as minidom
# 创建文档实例
dom = minidom.getDOMImplementation().createDocument(None,'Root',None)
# 获得根节点
root = dom.documentElementfor i in range(5):# 创建节点element = dom.createElement('Name')# 给这个节点添加数据element.appendChild(dom.createTextNode('default'))# 设置属性element.setAttribute('age', str(i))# 添加到节点root.appendChild(element)
# 保存文件  相对与原始的写入回自动缩进
with open('own.xml', 'w', encoding='utf-8') as f:dom.writexml(f, addindent='\t', newl='\n',encoding='utf-8')# 文档内容
<?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># ==================================
如果需要将已经写好的xml文件进行缩进处理
可以执行以下代码  root 是获取的根节点
import xml.etree.ElementTree as ET
from xml.dom import minidomdef 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")
# 获取根节点
root = dom.documentElement
# 按照名称查找字节点, 注意这里 回递归查找所有子节点  所有的子节点: root.childNodes
names = root.getElementsByTagName("Name")
for name in names:print(name.childNodes[0].nodeValue, end="\t")# 查询name是否含有属性ageif name.hasAttribute("age"):# 产看属性ageprint(name.getAttribute("age"), end="\t")print("")

2. 基于ElementTree

写入

# 导入
# -*- 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 = ifor elem in elem:__indent(elem, level+1)if not elem.tail or not elem.tail.strip():elem.tail = ielse:if level and (not elem.tail or not elem.tail.strip()):elem.tail = iroot = ET.Element('Root')       # 创建节点
tree = ET.ElementTree(root)     # 创建文档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)# 文档内容
<?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')
# 获取根节点
root = tree.getroot()
# 获取所有子节点 list(root)
# 查找所有子节点(非递归) 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寻找节点,获取子节点方法 list(节点),获取节点属性 get(属性名),下一级节点的值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、字典转换为xml文件:

使用dicttoxml模块,方法:dicttoxml.dicttoxml(字典数据,根节点名称 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文件转为字典:

使用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)#可以通过d['root']['arg']['#text']来访问节点中的文本值,d['root']['arg']['@p']来访问属性值
f.close()

4、字典转换为json

使用json的dumps方法

import json
data={'name':'bill','company':'huawei','age':30}
jsonstr=json.dumps(data)
print(jsonstr)

5、json转换为字典:

使用json模块的loads函数,传入json字符串,返回该字符串对应的字典

d=json.loads(jsonstr) print(d)

6、json转换为类实例,

1)、在指定的类中必须有一个接受字典的构造函数;或指定回调函数json2Product;

2)、使用json的loads方法(json字符串,object_hook=类名或者回调函数名)

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、 类实例转换为json:

1)、指定回调函数(product2Dict)

2、使用json的dump函数,指定default参数的回调函数import json

def product2Dict(product):return {'name': product.name,'price': product.price,'count': product.count}
strJson=json.dumps(products,default=product2Dict)
print(strJson)

8、字典转换为类:

1)、将字典转换为json

2)、json转换为类

import json
data=[{"name": "iPhone9", "price": 9999, "count": 3000}, {"name": "tesila", "price": 800000, "count": 122}]
# 将字典转换为json
jsonstr=json.dumps(data)
class Product:def __init__(self,d):self.__dict__=d
def json2Product(d):return Product(d)
# 将json转换为类
ps=json.loads(jsonstr,object_hook=Product)
for p in ps:print('name=', p.name, 'price=', p.price)

9、将类转换为字典:

1)、类转换为json,使用json的dumps方法

2)、json转为字典,使用json的loads方法

def product2Dict(product):return {'name': product.name,'price': product.price,'count': product.count}
# 将类转换为json
strJson=json.dumps(ps,default=product2Dict)
print(strJson)
d=json.loads(strJson)
print(d)

10、json转xml

1)、先将xml转换为字典

2)、再使用dicttoxml转换为字典

import json
import dicttoxml
f=open('products.json','r',encoding='utf-8')
jsonstr=f.read()
# 将json转换为字典
d=json.loads(jsonstr)
print(d)
# 将字典转换为xml
bxml=dicttoxml.dicttoxml(d,custom_root='fruit')
print(bxml)

11、将xml转换为json

1)、先使用xmltodict转换为字典

2)、再将字典转换为json

import xmltodict
import json
f=open('products.xml','r',encoding='utf-8')
d=f.read()
#先将xml转换为字典
data=xmltodict.parse(d)
print(data)
#再将字典转换为json
strjson=json.dumps(data)
print(strjson)

python中xml格式的转换相关推荐

  1. python中时间格式的转换(time模块)

    1.Unix时间戳 Unix时间戳是指格林威治时间1970年01月01日00时00分00秒(北京时间1970年01月01日08时00分00秒)起至现在的总秒数.例如:xxxxxxxx.xxxxx,单位 ...

  2. csv格式清洗与转换python_实例详解Python中 CSV格式清洗与转换

    Python中 CSV格式清洗与转换的实例代码 题目: CSV格式清洗与转换 描述 附件是一个CSV格式文件,提取数据进行如下格式转换:‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‭‬ ...

  3. xml python gb2312_使用Python处理XML格式数据的方法介绍

    本文实例讲述了Python处理XML格式数据的方法.分享给大家供大家参考,具体如下: 这里的操作是基于Python3平台. 在使用Python处理XML的问题上,首先遇到的是编码问题. Python并 ...

  4. python获取的html转换为json,python读取XML格式文件并转为json格式

    XML文件如下: 红楼梦书名> 曹雪芹作者> 描述贾宝玉和林黛玉的爱情故事主要内容> 人民文学出版社出版社> 图书> 一.python读取XML格式文件代码: impor ...

  5. python操作XML格式文件

    python操作XML格式文件 python操作XML格式文件 1. 读取文件和内容 2.读取节点数据 3.修改和删除节点 4.构建文档 python操作XML格式文件 可扩展标记语言,是一种简单的数 ...

  6. python中json与str转换和出现KeyError的解决方法

    python中json与str转换和出现KeyError的解决方法 json转str str转json KeyError的解决方法 json转str json格式的数据其实就是dict类型的数据,如图 ...

  7. python中的format什么意思中文-Python中format()格式输出全解

    格式化输出:format() format():把传统的%替换为{}来实现格式化输出 1.使用位置参数:就是在字符串中把需要输出的变量值用{}来代替,然后用format()来修改使之成为想要的字符串, ...

  8. 关于python中的字符串映射转换

    关于python中的字符串映射转换 利用Python字符串映射的方式来快速准确对Python字符串中对应的字符串进行替换,方法主要有两种: 第一种:maketrans方法 maketrans方法的参数 ...

  9. python中如何进行温度转换_python中温度单位转换的实例方法

    温度有摄氏度和华氏度两个单位,我们通常使用的是摄氏度,对于转换成华氏度,很多小伙伴记不住公式.作为万能的计算机,它是可以帮助我们解决温度单位转换的问题.本文主要演示python中进行温度单位转换的代码 ...

最新文章

  1. 这一次,你能彻底搞懂 Flink!
  2. Oracle ASM 翻译系列第十二弹:ASM Internal amdu - ASM Metadata Dump Utility
  3. linux NR==变量,LINUX中详解AWK内建变量FS,NF,NR,RT,RS,ORS,OFS
  4. redhat mysql tar_mysql5.7版本tar包手动安装---redhat7.0
  5. 2017年第八届蓝桥杯 —— 训练题目 —— 空瓶换汽水
  6. spark 应用程序性能优化:12 个优化方法
  7. C# 7.1先睹为快(第一部分)
  8. Linux/Document: Livepatch
  9. IEEE最新声明:华为员工不能参与审稿,但是还能继续提供赞助
  10. VS2010制作dll
  11. SPSS基础教程:SPSS菜单命令详解(三)
  12. python爬虫方向_爬虫实战(三) 用Python爬取拉勾网
  13. Android 白天黑夜模式切换换肤
  14. 数字人民币真的来了 六年历程全回顾
  15. OPCClient远程连接OPC服务器配置手册
  16. setBackground()和setImageBitmap()看完就哦了
  17. setvlet:控制台获取前端表单以及xml文件数据信息
  18. 最美的时间你遇见了谁
  19. [python] 基于Gradio可视化部署机器学习应用
  20. Python 中的正则表达式全部用法速查

热门文章

  1. matlab画图,添加图名,坐标轴名,曲线名称(图例)
  2. Android自动发送短信
  3. 开关电源基础01:电源变换器基础(1)-关于缘起
  4. 硕士生一字不差抄袭顶会论文投稿,北理工:严重学术不端,留校察看
  5. setTimeout与setTimeinterval的使用-2020年10月23日
  6. 07:收集瓶盖赢大奖
  7. 深度学习项目(二)对话机器人
  8. 数据可视化大屏-Vue-1图表基本配置
  9. excel部分网格线不见了_Excel中的灰框线不见了,怎么显示
  10. AR试妆:1秒模拟真实妆容,大牌彩妆尽情试