¥pickle模块¥

pickle模块

  • 用于python特有的类型 和 python的数据类型间进行转换

【1】序列化方法(dumps)

#导入模块
mport pickle
​
dic = {'k1': 'v1', 'k2': 'v2', 'k3': 'v3'}
str_dic = pickle.dumps(dic)
print(str_dic)
#返回一个二进制数据
b'\x80\x04\x95#\x00\x00\x00\x00\x00\x00\x00}\x94(\x8c\x02k1\x94\x8c\x02v1\x94\x8c\x02k2\x94\x8c\x02v2\x94\x8c\x02k3\x94\x8c\x02v3\x94u.'
print(type(str_dic))
# <class 'bytes'>

【2】反序列化方法(loads)

#导入模块
import pickle
​
dic = {'k1': 'v1', 'k2': 'v2', 'k3': 'v3'}
#序列化得到一个二进制数据
str_dic = pickle.dumps(dic)
print(str_dic)
# b'\x80\x04\x95#\x00\x00\x00\x00\x00\x00\x00}\x94(\x8c\x02k1\x94\x8c\x02v1\x94\x8c\x02k2\x94\x8c\x02v2\x94\x8c\x02k3\x94\x8c\x02v3\x94u.'
print(type(str_dic))
# <class 'bytes'>
​
#反序列化的数据
dic2 = pickle.loads(str_dic)
print(dic2) 
# {'k1': 'v1', 'k2': 'v2', 'k3': 'v3'}
print(type(dic2))
# <class 'dict'>

【3】写入文件(dump)

import pickle
import time
​
struct_time = time.localtime()
print(struct_time)
# time.struct_time(tm_year=2023, tm_mon=11, tm_mday=25, tm_hour=20, tm_min=9, tm_sec=46, tm_wday=5, tm_yday=329, tm_isdst=0)
​
# 打开文件,并将句柄给 f
f = open('pickle_file', 'wb')
# 向 pickle_file 文件中写入数据
pickle.dump(struct_time, f)
# 完成写入,关闭文件
f.close()
  • 写入到 pickle_file 文件里面的数据是一堆乱码,看不懂

【4】读文件数据(load)

import pickle
import time
​
struct_time = time.localtime()
print(struct_time)
# time.struct_time(tm_year=2024, tm_mon=5, tm_mday=9, tm_hour=16, tm_min=53, tm_sec=50, tm_wday=3, tm_yday=130, tm_isdst=0)
# 打开文件,并将句柄给 f
f = open('pickle_file', 'wb')
# 向 pickle_file 文件中写入数据
pickle.dump(struct_time, f)
# 完成写入,关闭文件
f.close()
​
# 打开文件的句柄
f = open('pickle_file', 'rb')
# 将读出来的数据给 struct_time2
struct_time2 = pickle.load(f)
​
# 我们可以直接操作 struct_time2 --- 上面直接写入的时间元组对象
print(struct_time2)
#time.struct_time(tm_year=2024, tm_mon=5, tm_mday=9, tm_hour=16, tm_min=53, tm_sec=50, tm_wday=3, tm_yday=130, tm_isdst=0)
​
print(type(struct_time2))
# <class 'time.struct_time'>
print(struct_time2.tm_year)
# 2024
  • 先写数据---再读

【5】小结

  • 这时候机智的你又要说了,既然pickle如此强大,为什么还要学json呢?

  • 这里我们要说明一下

    • json是一种所有的语言都可以识别的数据结构。

  • 如果我们将一个字典或者序列化成了一个json存在文件里

    • 那么java代码或者js代码也可以拿来用。

  • 但是如果我们用pickle进行序列化

    • 其他语言就不能读懂这是什么了~

  • 所以,如果你序列化的内容是列表或者字典,我们非常推荐你使用json模块

  • 如果出于某种原因你不得不序列化其他的数据类型,而未来你还会用python对这个数据进行反序列化的话,那么就可以使用pickle

  • 6
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值