python在使用pickle反序列化时报错:数据被截断,无法进行反序列化

本文探讨了Python pickle模块在反序列化时遇到的‘数据被截断’错误。问题出现在socket通信中,接收方由于一次性接收的数据不足导致pickle.UnpicklingError。解决方案是接收并拼接多个数据包后再进行反序列化。
摘要由CSDN通过智能技术生成

python的序列化和反序列化之pickle

pickle模块实现了用于序列化和反序列化Python对象结构的二进制协议。 “Pickling”是将Python对象层次结构转换为字节流的过程, “unpickling”是反向操作,从而将字节流(来自二进制文件或类似字节的对象)转换回对象层次结构。
pickle是python特有的,只能用于python,不能拓展到其他语言,序列化的结果是字节类型,也可以在协议选项中选择二进制;json则类似于一种通用的模块,在其他语言中也可正常使用,序列化的结果是字符串。
pickle.dumps(object):将对象序列化,相当于json.dumps(object)
pickle.loads(object):将对象反序列化,相当于json.loads(object)
pickle.dump(object, file)、pickle.load(object, file)是对文件进行的操作,具体使用方法可以自行查询。

问题描述:

使用pickle序列化和反序列化进行socket传输时,发送方可以正常执行,接收方报错:_pickle.UnpicklingError: pickle data was truncated

通信双方代码:

@发送方
	connection, address = sock.
  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值