Python 如何向服务端提交 pickle.dumps 产生的 bytes(要保真)?

2019-03-31 02:07:17 +08:00
 eunha

服务端收到时 bytes 变成了字符串,而且有乱码,还原不回去了 pickle.dumps 返回的 bytes,不知道其使用了什么编码,如 pickle.dumps({})会返回 b'\x80\x03}q\x00.'

这样的数据,用 utf-8 解码无法解码: UnicodeDecodeError: 'utf-8' codec can't decode byte 0x80 in position 0: invalid start byte

而用 utf-16 解码则不可逆: in: b out: b'\x80\x03}q\x00.' in: b.decode(encoding='utf-16').encode(encoding='utf-16') out: b'\xff\xfe\x80\x03}q\x00.'

求可逆的这种 bytes 转换为 str 的方法,如果能获取 post 的原始数据就更感激不尽了

1453 次点击
所在节点    Python
2 条回复
forestLittleBear
2019-03-31 14:22:50 +08:00
流弊。
不知道使用什么编码可还行。。。
不知道编码格式怎么解码。。。?
lolizeppelin
2019-04-01 17:29:36 +08:00
用 struct 谢谢
pickle 是 python 自己用的

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/550412

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX