Python中json模块能做什么,用法是怎样的
Admin 2022-08-12 群英技术资讯 387 次浏览
在python中,json模块可以实现json数据的序列化和反序列化
def dump(obj, fp, *, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, default=None, sort_keys=False, **kw):
def dumps(obj, *, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, default=None, sort_keys=False, **kw):
4.把obj序列化成一个json格式的字符串,并返回该字符串支持的python内置可进行json序列化的类型有(str, int, float, bool, None,list,tuple,dict)如果无法序列化的类型,会抛出TypeError
2.其他参数同上解释
def load(fp, *, cls=None, object_hook=None, parse_float=None, parse_int=None, parse_constant=None, object_pairs_hook=None, **kw):
def loads(s, *, cls=None, object_hook=None, parse_float=None, parse_int=None, parse_constant=None, object_pairs_hook=None, **kw):
6.parse_constant 如果定义了,那么在碰到-Infinity, Infinity, NaN.这些的时候会被调用;如果遇到无效的json符号,会抛出异常
import json if __name__ == '__main__': # 测试格式化非json格式数据 print('-------------测试格式化非json格式数据----------------') a = json.dumps(2.0) print(a, type(a)) a = json.dumps(tuple()) print(a, type(a)) a = json.dumps([]) print(a, type(a)) # 测试格式化json格式数据 print('-------------测试格式化json格式数据----------------') j = {'a': 1, 'b': 6} a = json.dumps(j) print(a, type(a)) # 测试skipkeys参数 print('-------------测试skipkeys参数----------------') j = {'a': 1, tuple(): 6} a = json.dumps(j, skipkeys=True) print(a, type(a)) # 测试indent参数 print('-------------测试indent默认参数----------------') j = {'a': 1, 'b': 234} a = json.dumps(j) print(a, type(a)) print('-------------测试indent=0参数----------------') a = json.dumps(j, indent=0) print(a, type(a)) print('-------------测试indent=2参数----------------') a = json.dumps(j, indent=2) print(a, type(a)) print('-------------测试separators参数----------------') a = json.dumps(j, separators=('[', ']')) print(a, type(a))
import json if __name__ == '__main__': # 测试格式化非json格式数据 fp = open('./json_dump_data', mode='w') print('-------------测试格式化非json格式数据----------------') a = json.dump(2.0, fp) fp.write('\n') a = json.dump(tuple(), fp) a = json.dump([], fp) fp.write('\n') # 测试格式化json格式数据 j = {'a': 1, 'b': 6} a = json.dump(j, fp)
cat json_dump_data:
1和2中很多参数都是相同的,这里就不再详述3.load()
import json if __name__ == '__main__': j = open('./json_data', mode='r') # 测试默认参数 a = json.load(j) print('-------------测试默认参数----------------') print(a) # 测试object_hook参数 j = open('./json_data', mode='r') a = json.load(j, object_hook=lambda x: x.get('b')) print('-------------测试object_hook参数----------------') print(a) # 测试object_pairs_hook参数 j = open('./json_data', mode='r') loads = json.load(j, object_pairs_hook=lambda x: print(type(x), type(x[2]))) print('-------------测试object_pairs_hook参数----------------') print(loads) # 测试parse_constant参数 j = open('./json_data', mode='r') loads = json.load(j, parse_constant=lambda x: 'not notification') print('-------------测试parse_constant参数----------------') print(loads) # 测试parse_int参数 j = open('./json_data', mode='r') loads = json.load(j, parse_int=lambda x: 'cutomer int') print('-------------测试parse_int参数----------------') print(loads) # 测试parse_float参数 j = open('./json_data', mode='r') loads = json.load(j, parse_float=lambda x: 'cutomer float') print('-------------测试parse_float参数----------------') print(loads)
注:
因为load方法的底层是调用了fp.read(),所以每一次重新调用load的时候都需要重新打开文件句柄。不然就会导致在第二次调用load方法的时候,就会因为fp.read()返回的是none就导致异常
import json if __name__ == '__main__': j = '{"a":1,"b":2.0,"c":Infinity}' # 测试默认参数 a = json.loads(j) print('-------------测试默认参数----------------') print(a) # 测试object_hook参数 a = json.loads(j, object_hook=lambda x: x.get('b')) print('-------------测试object_hook参数----------------') print(a) # 测试object_pairs_hook参数 loads = json.loads(j, object_pairs_hook=lambda x: print(type(x), type(x[2]))) print('-------------测试object_pairs_hook参数----------------') print(loads) # 测试parse_constant参数 loads = json.loads(j, parse_constant=lambda x: 'not notification') print('-------------测试parse_constant参数----------------') print(loads) # 测试parse_int参数 loads = json.loads(j, parse_int=lambda x: 'cutomer int') print('-------------测试parse_int参数----------------') print(loads) # 测试parse_float参数 loads = json.loads(j, parse_float=lambda x: 'cutomer float') print('-------------测试parse_float参数----------------') print(loads)
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
内容介绍1.引言2.工作原理3.使用Colorama库4.改变输出文本颜色5.改变输出文本背景6.改变输出文本亮度7.总结1.引言创建命令行程序很棒:命令行可以按照我们的设定完成相应的工作,相比GU
NumPy(Numerical Python)是Python的一种开源的数值计算扩展。这种工具可用来存储和处理大型矩阵。但其实NumPy还可以绘制图画,本文将为大家介绍如何通过NumPy绘制彩色图画,感兴趣的小伙伴可以了解一下
在日常运维中, 经常遇到这样的情况: 系统自带的Python是2.x,而业务部署需要Python 3.x 环境, 此时需要在系统中安装多个Python版本,但又不能影响系统自带的Python 版本,即需要实现Python的多版本环境共存, pyenv就是这样一个Python版本管理器, 可以同时管理多个python版本共存! 简单的说,pyenv 可以根据需求使用户在系统里安装和管理多个Python 版本:
在Python使用字符串的过程中,如果遇到很多的字符串,想要查找到想要的字符串有些困难。本文主要介绍Python字符串查找的几种方法:find方法、 index方法、rfind方法、rindex方法。具体请看如下内容:
这篇文章主要为大家介绍了Python实现GB格式序列文件转换Fasta格式文件示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008