python protobuf无法反序列化消息

时间:2017-10-10 20:06:04

标签: python protocol-buffers

在python中开始使用protobuf我面临一个奇怪的问题:

一个简单的消息原型定义是:

syntax = "proto3";
package test;

message Message {
  string message = 1;
  string sender = 2;
}

通过protoc -I . --python_out=generated message.proto生成并在Python中访问,如:

from generated.message_pb2 import Message

然后我可以构建一条消息

m = Message()
m.sender = 'foo'
m.message = 'bar'

print(str(m))

但反序列化不会返回结果

s_m = m.SerializeToString()
print(s_m) # prints fine
a = m.ParseFromString(s_m)
a.foo #fails with error - no attributes deserialized

1 个答案:

答案 0 :(得分:2)

而不是

a = m.ParseFromString(s_m)
a.foo

这样做

a = m.FromString(s_m)
print a.sender

或者你可以这样做

m2 = Message()
m2.ParseFromString(s_m)
print m2.sender

不同之处在于FromString返回从字符串反序列化的新对象,而ParseFromString解析字符串并设置对象上的字段。