在Protobuf中,如果你尝试访问一个未定义的字段,行为会根据你是如何访问该字段的来决定。
在Python中使用Protobuf时,如果你尝试获取一个未在.proto文件中定义的字段,你会得到一个AttributeError,因为在编译生成的Python类中不存在这个字段的属性。
例如,考虑下面的Protobuf消息定义:
message ExampleMessage { string field1 = 1; }
对应的Python代码尝试访问一个不存在的字段:
import example_pb2
message = example_pb2.ExampleMessage()
print(message.field1)
# 这是正常的,因为 field1 在.proto文件中被定义了
print(message.field2)
# 这会引发错误,因为 field2 没有在.proto文件中定义
在尝试打印message.field2时,将会抛出一个AttributeError,因为没有这个属性存在于由Protobuf编译器生成的Python类中。
如果你是使用动态访问(例如使用getattr函数),那么如果属性不存在,Python 的行为是可以通过一个默认值来避免抛出错误的:
print(getattr(message, 'field2', 'DefaultValue'))
# 将输出 DefaultValue 而不是抛出错误
在这个例子中,尝试访问field2,但是因为它不存在,所以getattr函数返回了提供的默认值'DefaultValue'。
总的来说,直接通过属性名访问不存在的字段会导致错误,而使用像getattr这样的内置函数可以提供默认值来避免错误。当处理Protobuf对象时,始终最好只访问那些在.proto文件中明确声明的字段。
4862

被折叠的 条评论
为什么被折叠?



