使用以太坊RLP编码的MessagePack(反)序列化程序
msgpack-rlp-python的Python项目详细描述
这个库使用msgpack的修改版本来编码和解码二进制文件。 数据根据以太坊RLP规范这里https://github.com/ethereum/wiki/wiki/RLP
这是这个库的第一个版本,很可能仍然存在bug。使用风险自负。
安装
$ pip install msgpack-rlp-python
用法
rlp没有指定变量类型,因此所有编码的数据都被解码为bytestring表示。 为了指定变量类型,我们使用sedes。sedes是一种表达方式 程序你期望从编码的数据中得到什么样的变量类型。在这个版本中 支持的sede只有2个:字节(由整数0表示)和整数(由整数1表示)。这些沉淀物也可以 在列表或嵌套列表中。以显示sede位于列表中或嵌套中 列表,我们使用标准的python列表表示法。见下文。
- 默认情况下,所有列表都将解码为元组。要解码到列表集,请使用list=true
- sedes只在解码时使用。这个库足够聪明,可以知道正在编码的变量类型,并将它们正确地转换为rlp规范。
- 这意味着它是msgpack的替代品。所以要导入的包仍然称为msgpack。
sedes示例:
var = b'\x01'
sede = 0 # A bytestring
var = 12381239
sede = 1 # An integer
var = [b'\x01', b'\x02', b'\x03', b'\x04']
sede = [0] # A list of bytestrings
var = [12312,1234,213412,213421]
sede = [1] # A list of integers
var = [b'\x01', [12312,1234]]
sede = [0,[1]] # Different types, and nested lists
不含sedes的示例用法。这将始终解码为bytestrings。
>>> importmsgpack>>> msgpack.packb([1,2,3])'b'\xc3\x01\x02\x03'' >>> msgpack.unpackb(_)(b'\x01', b'\x02', b'\x03') >>> msgpack.packb([1,2,3])'b'\xc3\x01\x02\x03'' >>> msgpack.unpackb(_,use_list=True)[b'\x01', b'\x02', b'\x03']
使用sedes的示例。这将解码为您从中编码的变量类型。
>>> importmsgpack>>> msgpack.packb([1,2,3])'b'\xc3\x01\x02\x03'' >>> msgpack.unpackb(_)(b'\x01', b'\x02', b'\x03') >>> msgpack.packb([1,2,3])'b'\xc3\x01\x02\x03'' >>> msgpack.unpackb(_,sedes=[1],use_list=True)[1, 2, 3] >>> msgpack.packb([b'\x01',[12312,1234]])b'\xc8\x01\xc6\x820\x18\x82\x04\xd2' >>> msgpack.unpackb(_,sedes=[0,[1]],use_list=True)[b'\x01', [12312, 1234]] >>> msgpack.packb([b'\x01',[12312,1234]])b'\xc8\x01\xc6\x820\x18\x82\x04\xd2' >>> msgpack.unpackb(_,sedes=[0,[1]],use_list=True)[b'\x01', [12312, 1234]]