首页 / JSON / python-- json 序列化
python-- json 序列化
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了python-- json 序列化,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3227字,纯文字阅读大概需要5分钟。
内容图文
![python-- json 序列化](/upload/InfoBanner/zyjiaocheng/595/48130158b33c47efa0516944c5a75706.jpg)
前戏
序列化:得到一个字符串的过程就叫序列化
字典 / 列表 / 数字 /对象 -经过序列化 --->字符串
字符串-反序列化 ---> 字典 / 列表 / 数字 /对象
为什么要序列化
- 要把内容写入文件 序列化
- 网络传输数据 序列化
json
转为字符串 dumps
import json dic = {"aaa": "bbb", "ccc": "ddd"} str_dic = json.dumps(dic) print(dic, type(dic)) print(str_dic, type(str_dic))
结果:
{'aaa': 'bbb', 'ccc': 'ddd'} <class 'dict'> {"aaa": "bbb", "ccc": "ddd"} <class 'str'>
反序列化 loads
import json # 只提供四个方法 dic = '{"aaa":"bbb","ccc":"ddd"}' str_dic = json.loads(dic) print(dic, type(dic)) print(str_dic, type(str_dic))
结果:
{"aaa":"bbb","ccc":"ddd"} <class 'str'> {'aaa': 'bbb', 'ccc': 'ddd'} <class 'dict'>
如果要将字典写入文件,要先序列化后再写入
import json dic = {"aaa": "bbb", "ccc": "ddd"} str_dic = json.dumps(dic) # 将字典转为字符串 with open('json_dump', 'w') as f: f.write(str_dic)
也可以使用 dump 写入,不需要转为字符串
import json dic = {'aaa': 'bbb', 'ccc': 'ddd'} with open('json_dump2', 'w') as f: json.dump(dic, f) # 第一个参数为要写入的内容,第二个参 数为文件句柄从文件里读取出来就是反序列化后的,用load,但是文件里的字符串必须是英文状态下的双引号,如果是单引号则会报错
import json with open('json_dump2', 'r', encoding='utf-8') as f: ret = json.load(f) print(ret)
json模块其他用法
json 格式的限制
# json格式的限制1,json格式的key必须是字符串数据类型 # json格式中的字符串只能是"" # set不能被dump/dumps如果是数字为key,那么dumps之后会强行转成字符串数据类型
import json
dic = {1:2,3:4} str_dic = json.dumps(dic) print(str_dic)
new_dic = json.loads(str_dic) print(new_dic)
结果
{"1": 2, "3": 4} {'1': 2, '3': 4}json支持元组做value,对元组做value的字典,会把元组强制转换成列表
import json dic = {'abc': (1, 2, 3)} str_dic = json.dumps(dic) print(str_dic) new_dic = json.loads(str_dic) print(new_dic)
结果:
{"abc": [1, 2, 3]} {'abc': [1, 2, 3]}json不支持元组做key
import json dic = {(1, 2, 3): 'abc'} str_dic = json.dumps(dic) # 报错对列表的dump
import json lst = ['aaa', 123, 'bbb', 12.456] with open('json_demo', 'w') as f: json.dump(lst, f) with open('json_demo') as f: ret = json.load(f) print(ret)
结果:
['aaa', 123, 'bbb', 12.456]可以多次dump数据到文件里,但是不能load出来了
import json dic = {'abc': (1, 2, 3)} lst = ['aaa', 123, 'bbb', 12.456] with open('json_demo', 'w') as f: json.dump(lst, f) json.dump(dic, f) with open('json_demo') as f: ret = json.load(f) # 会报错 print(ret)
import json dic = {'abc': (1, 2, 3)} lst = ['aaa', 123, 'bbb', 12.456] with open('json_demo', 'w') as f: str_lst = json.dumps(lst) str_dic = json.dumps(dic) f.write(str_lst + '\n') f.write(str_dic + '\n')
with open('json_demo') as f: for line in f: ret = json.loads(line) print(ret)
结果:
['aaa', 123, 'bbb', 12.456] {'abc': [1, 2, 3]}中文格式的 ensure_ascii = False
import json dic = {'abc': (1, 2, 3), 'country': '中国'} ret = json.dumps(dic, ensure_ascii=False) print(ret)
dic_new = json.loads(ret) print(dic_new)
结果
{"abc": [1, 2, 3], "country": "中国"} {'abc': [1, 2, 3], 'country': '中国'}不加ensure_ascii = False,写进去是unicode编码,读取出来还是汉字
json的其他参数
import json data = {'username': ['李华', '二愣子'], 'sex': 'male', 'age': 16} json_dic2 = json.dumps(data, sort_keys=True, indent=4, separators=(',', ':'), ensure_ascii=False) print(json_dic2)
结果:
{ "age":16, "sex":"male", "username":[ "李华", "二愣子" ] }
sort_keys=True,key按照ascii排序
indent缩进几个字符
ensure_ascii不以ascii编码
内容总结
以上是互联网集市为您收集整理的python-- json 序列化全部内容,希望文章能够帮你解决python-- json 序列化所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。