时间:2021-05-22
本文实例讲述了python实现class对象转换成json字典的方法。分享给大家供大家参考,具体如下:
# -*- encoding: UTF-8 -*-class Student: name = '' age = 0 def __init__(self, name, age): self.name = name self.age = agedef convert_to_dict(obj): '''把Object对象转换成Dict对象''' dict = {} dict.update(obj.__dict__) return dictdef convert_to_dicts(objs): '''把对象列表转换为字典列表''' obj_arr = [] for o in objs: #把Object对象转换成Dict对象 dict = {} dict.update(o.__dict__) obj_arr.append(dict) return obj_arrdef class_to_dict(obj): '''把对象(支持单个对象、list、set)转换成字典''' is_list = obj.__class__ == [].__class__ is_set = obj.__class__ == set().__class__ if is_list or is_set: obj_arr = [] for o in obj: #把Object对象转换成Dict对象 dict = {} dict.update(o.__dict__) obj_arr.append(dict) return obj_arr else: dict = {} dict.update(obj.__dict__) return dictstu = Student('zhangsan', 20)print '-----------'print convert_to_dict(stu)print '-----------'print convert_to_dicts([stu, stu])print '-----------'print class_to_dict(stu)print '-----------'print class_to_dict([stu, stu])stua = Student('zhangsan', 20)stub = Student('lisi', 10)stu_set = set()stu_set.add(stua)stu_set.add(stub)print class_to_dict(stu_set)运行结果如下:
-----------{'age': 20, 'name': 'zhangsan'}-----------[{'age': 20, 'name': 'zhangsan'}, {'age': 20, 'name': 'zhangsan'}]-----------{'age': 20, 'name': 'zhangsan'}-----------[{'age': 20, 'name': 'zhangsan'}, {'age': 20, 'name': 'zhangsan'}][{'age': 10, 'name': 'lisi'}, {'age': 20, 'name': 'zhangsan'}]希望本文所述对大家Python程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
实际上JSON就是Python字典的字符串表示,但是字典作为一个复杂对象是无法直接传递,所以需要将其转换成字符串形式.转换的过程也是一种序列化过程.用json.
python操作json的方法有json.dumps——将json对象(字典)转换为字符串对象json.loads——将字符串对象转换为json对象(字典)如果
把Excel表单转换成json对象,并保存到一个文本文件中,并支持生成C#class数据定义代码。软件名称:Excel表格快速转换成JSON字符串的工具软件大小
在python中可以使用json将数据格式化为JSON格式:1.将字典转换成JSON数据格式:s=['张三','年龄','姓名']t={}t['data']=s
python中自带了处理python的模块,使用时候直接importjson即可。使用loads方法即可将json字符串转换成python对象,对应关系如下:J