我正在使用python protobuf v2.6.1的动态反射功能,并且具有如下功能:
# initilization code
des_db_ = descriptor_database.DescriptorDatabase()
des_pool_ = descriptor_pool.DescriptorPool(des_db_)
fdp = descriptor_pb2.FileDescriptorProto.FromString(
a_pb_module.DESCRIPTOR.serialized_pb)
des_db_.Add(fdp)
def unpack_PB_msg(type_name, pb_msg_str)
factory = message_factory.MessageFactory(des_pool_)
msg_class = factory.GetPrototype(des_pool_.FindMessageTypeByName(type_name))
pb_msg = msg_class()
pb_msg.ParseFromString(pb_msg_str)
return pb_msg
但是关注客户端代码将失败
hello = Hello_msg()
hello_str = hello.SerializeToString()
hello2 = unpack_PB_msg(Hello_msg.DESCRIPTOR.full_name, hello_str)
hello3 = Hello_msg()
hello3.CopyFrom(hello2)# failed here!!!
错误消息是:
hello3.CopyFrom(hello2)
File "C:\Localdata\Python27\lib\site-packages\google\protobuf\message.py", line 119, in CopyFrom
self.MergeFrom(other_msg)
File "C:\Localdata\Python27\lib\site-packages\google\protobuf\internal\python_message.py", line 971, in MergeFrom
"expected %s got %s." % (cls.__name__, type(msg).__name__))
TypeError: Parameter to MergeFrom() must be instance of same class: expected Hello_msg got Hello_msg.
似乎CopyFrom失败,因为isinstance失败。
def MergeFrom(self, msg):
if not isinstance(msg, cls):
raise TypeError(
"Parameter to MergeFrom() must be instance of same class: "
"expected %s got %s." % (cls.__name__, type(msg).__name__))
当打印hello2和hello3的数据类型时,它们似乎是不同的。
hello2 : <class 'Hello_msg'>
hello3 : <class 'a_pb_module.Hello_msg'>
这是一个protobuf错误吗?或者我做错了什么?
答案 0 :(得分:2)
这可能能够帮助某人。 我有同样的错误
2
当我在两个不同的路径上两次导入相同的类时,它导致在不同的路径上导入两个不同的类(即使它们可能具有相同的类名,Python将它们视为两个完全不同的类(检查ID的上课,你应该发现它们是不同的))。
要解决此问题,您需要确保仅导入同一个类(Hello_msg)一次。