Python中xml、字典、json、类四种数据的转换

转载自 https://www.cnblogs.com/dafa638/p/9952790.html

 

之前都是直接拿sax,或dom等库去解析xml文件为Python的数据类型再去操作,比较繁琐,如今在写Django网站ajax操作时json的解析,发现这篇帖子对这几种数据类型的转换操作提供了另一种更简洁的方法,xmltodictdicttoxml等库功不可没,几种转换方式也都比较全面,转存一下以备不时之需,感谢原创整理!

注:xml、字典、json、类四种数据的转换,从左到右依次转换,即xml要转换为类时,先将xml转换为字典,再将字典转换为json,
最后将json转换为类。
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)

 

转载于:https://www.cnblogs.com/pozhu15/p/11309312.html

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Python可以使用不同的库来解析JSONXML数据。 对于JSON数据Python内置了json库,可以使用它来解析和生成JSON数据。使用json库可以将JSON数据转换Python对象,例如字典或列表,也可以将Python对象转换JSON数据。 对于XML数据Python可以使用许多不同的库来解析和生成XML数据。其一些库包括ElementTree、lxmlxml.etree.ElementTree。这些库允许将XML数据转换Python对象,例如Element对象或树,也可以将Python对象转换XML数据。 总的来说,Python提供了许多不同的库来解析和生成JSONXML数据,开发人员可以根据自己的需求选择最适合的库。 ### 回答2: 随着互联网的不断发展,数据的解析变得越来越重要,因为我们需要从大量的数据提取有用的信息来支持决策和业务流程。在Python,我们可以使用两种主要格式来解析数据JSONXMLJSON(JavaScript Object Notation)是一种轻量级的数据交换格式,以易于人阅读和编写的形式表示数据对象。JSON使用键值对的方式存储数据似于Python字典JSON格式的一个优点是它可以直接在Javascript读取和处理,这使它成为Web应用程序最常用的数据格式之一。PythonJSON模块可以轻松地将JSON数据解析成Python对象,反之亦然。我们使用JSON来解析Web API的响应和其他数据源。 XML(eXtensible Markup Language)是一种标记语言,似于HTML,但是它没有预定义的标记集合,并且可以扩展以创建任何定制标记。XML使用标记将数据存储在树形结构,这使数据解析更容易。XML格式支持命名空间、错误处理和文档型定义(DTD),这使得XML成为数据交换和存储的可扩展标准。在Python,我们可以使用标准库的ElementTree模块来解析XML文档,也可以使用第三方库例如lxmlxmltodict。 在数据解析方面,JSONXML都有自己的优点和缺点。JSON更适合用于Web应用程序和结构化数据,而XML更适合用于大型的、可扩展的数据格式和在数据包含大量文本的情况。因此,在选择使用哪种格式时,需要考虑需要解析的数据型和结构。 需要注意的是,对于大型数据集和性能要求较高的情况下,我们可以使用Python的C扩展模块,或者使用一些特殊的解析器,例如Cython、numba等。这些工具可以大幅提高程序性能。 无论使用哪种工具,数据解析都是Python非常重要的一环,并且在实际工作和编程都有广泛的应用。希望以上介绍能够帮助读者更好的理解和应用Python数据解析技术。 ### 回答3: 在Python,对于数据解析,最常用的格式是JSONXMLJSON(JavaScript对象表示法)是一种轻量级的数据交换格式,它基于JavaScript语言标准来创建,由键值对组成。XML(可扩展标记语言)是一种通用的标记语言,用于描述数据和传输数据。现在,我们来看一下Python如何解析JSONXML数据。 对于JSON数据的解析,首先需要将其解析成Python对应的数据结构。在Python,有一个内置模块json,可以轻松完成JSON数据的解析。具体的方法是使用json.loads()函数进行解析,该函数将JSON数据转换Python字典或列表。 比如,我们有以下JSON数据: { "name": "John", "age": 30, "city": "New York" } 我们可以用下面的代码将其解析成Python字典: import json json_data = '{"name": "John", "age": 30, "city": "New York"}' python_data = json.loads(json_data) print(python_data) 输出结果为: {'name': 'John', 'age': 30, 'city': 'New York'} 对于XML数据的解析,我们需要使用Python的一个内置模块—xml.etree.ElementTree。这个模块可以方便地解析XML数据,并将其转换Python字典或列表。 比如,我们有以下XML数据: <person> <name>John</name> <age>30</age> <city>New York</city> </person> 我们可以用下面的代码将其解析成Python字典: import xml.etree.ElementTree as ET xml_data = '''<person> <name>John</name> <age>30</age> <city>New York</city> </person>''' root = ET.fromstring(xml_data) person = {} for child in root: person[child.tag] = child.text print(person) 输出结果为: {'name': 'John', 'age': '30', 'city': 'New York'} 总之,无论是解析JSON还是XMLPython都提供了非常方便的内置函数和模块,可以轻松地完成数据解析。在实际应用,我们可以根据需要选择适合自己的数据格式,以方便数据的传输和处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值