【Python】序列化与反序列化

2019-04-17  本文已影响0人  失语失芯不失梦

import json

简单直接来讲,序列化是指把python的数据对象转换为json格式的字符串(list、dict—> str);反序列化是指把json格式字符串转换为python数据对象(str—> list、dict)

序列化方法:json.dumps / json.dump 

对数据对象进行序列化:json.dumps

对数据对象进行序列化处理 输出结果

如果在序列化时,中文汉字被转换为unicode码,在dumps函数中添加参数ensure_ascii=False即可解决,以上可处理为:print(json.dumps(dict, ensure_ascii=False))

输出结果

对文件进行序列化:json.dump

分两步走:先序列化数据对象,然后再将序列化后的字符串写入文件中

对文件进行序列化 输出结果

反序列化方法:json.loads / json.load

对数据对象进行反序列化:json.loads

对数据对象进行反序列化处理 输出结果

注意:这里我遇到过两个错误

1)json.decoder.JSONDecodeError: Expecting property name enclosed in double quotes: line 1 column 2 (char 1)

最开始我是这么写的string,然后把大括号里面改成双引号就不会报这个错了。结果,报出了第二种错

2)  SyntaxError: invalid syntax:报这个错之后,我就试图把大括号外面的双引导改成单引号,结果就正常了

对文件进行反序列化:json.load

同样分两步走:先读取文件的字符串对象,然后反序列化成python数据对象

再把上一步中的文件内容反序列化回来 输出结果

对文件的序列化或者反序列化操作,一定要注意!!!dump/load方法里面一定要写open(),而不是写变量名!!!!!!就比如上图对文件反序列化的操作,我改成下图这样:

会报错:json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0)

我也不知道为什么,明明open('D:\\Daydayup\\2.txt', 'r')就是赋值给file的,不过就先这样记住吧

上一篇 下一篇

猜你喜欢

热点阅读