当使用python protobuf v2.6.1

时间:2015-08-05 21:23:32

标签: python protocol-buffers

我正在使用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错误吗?或者我做错了什么?

1 个答案:

答案 0 :(得分:2)

这可能能够帮助某人。 我有同样的错误

2

当我在两个不同的路径上两次导入相同的类时,它导致在不同的路径上导入两个不同的类(即使它们可能具有相同的类名,Python将它们视为两个完全不同的类(检查ID的上课,你应该发现它们是不同的))。

要解决此问题,您需要确保仅导入同一个类(Hello_msg)一次。