文件的序列化和反序列化
通过文件操作,我们可以将字符串写入到一个本地文件。但是,如果是一个对象(例如列表、字典、元组等),就无直接写入到本地文件。
设计一套协议,按照某种规则,把内存中的数据转换为字节序列,保存到文件,这就是序列化、
对象 --> 字节序列 === 序列化
字节序列 --> 对象 === 反序列化
python中提供了json这个模块用来实现数据的序列化和反序列化
JSON是本质上是一个带有特定格式的字符串!
使用JSON实现序列化
fp = open('test.txt','w')//对文件操作的习惯最好在写之前就把close写好,不然容易忘
name_list = ['张三','李四','王五']
如果直接把name_list写入write的括号中会报错,意思是write接收的参数必须是字符串的类型
fp.write('hello world')
fp.close()
with open() as f:这样打开文件,能够自动关闭文件
with open("D:/c.txt","r") as f: #f是文件对象
for Line in f:
print(f"每一行数据:{line}")
#序列化的两种方式
#dumps()
1.创建一个文件
fp = open('test.txt','w')
2.定义一个列表
name_list = ['张三','李四','王五']
3.引入json模块
import json
4.序列化 将python对象 变成json字符串
此时names的类型为str
names = json.dumps(name_list)
5.将names写入到文件中
fp.write(names)
fp.close()
//写入到文件中的为 ['张三','李四','王五']
//我们在使用scrapy框架的时候 该框架会返回一个对象 我们要将对象写入到文件中 就要使用json.dumps
#dump
#在将对象转换为字符串的同时 指定一个文件的对象 然后把转换后的字符串写入到这个文件里
1.创建一个文件
fp = open('test.txt','w')
2.定义一个列表
name_list = ['张三','李四','王五']
3.引入json模块
import json
4.使用dump写入
相当于names = json.dumps(name_list)和fp.write(names)
json.dump(name_list,fp)
fp.close()
反序列化
将json的字符串变成一个python对象
fp = open('test.txt','r')
content = fp.read()
#loads
import json
//将json字符串变成python对象
json.loads(content)
#load
fp = open('test.txt','r')
import json
json.load(fp)
fp.close()
序列化和反序列化
最新推荐文章于 2024-07-20 15:39:26 发布