发布时间:2019-09-12 08:01:18编辑:auto阅读(1687)
ProtoBuf: 是一套完整的 IDL(接口描述语言),出自Google,基于 C++ 进行的实现,开发人员可以根据 ProtoBuf 的语言规范生成多种编程语言(Golang、Python、Java 等)的接口代码,本篇只讲述 Python 的基础操作。据说 ProtoBuf 所生成的二进制文件在存储效率上比 XML 高 3~10 倍,并且处理性能高 1~2 个数量级,这也是选择 ProtoBuf 作为序列化方案的一个重要因素之一。
配置 protoc 到系统的环境变量中,执行如下命令查看是否安装成功:
$ protoc –version
如果正常打印 libprotoc 的版本信息就表明 protoc 安装成功
安装 ProtoBuf 相关的 python 依赖库
$ pip install protobuf
创建 demo python 工程
在 example 包中编写 person.proto
syntax = "proto3";
package example;
message person {
int32 id = 1;
string name = 2;
}
message all_person {
repeated person Per = 1;
}
进入 demo 工程的 example 目录,使用 protoc 编译 person.proto
$ protoc –python_out=. person.proto
就会生成 person.pb2.py 文件
#! /usr/bin/env python
# -*- coding: utf-8 -*-
from example import person_pb2
# 为 all_person 填充数据
pers = person_pb2.all_person()
p1 = pers.Per.add()
p1.id = 1
p1.name = 'xieyanke'
p2 = pers.Per.add()
p2.id = 2
p2.name = 'pythoner'
# 对数据进行序列化
data = pers.SerializeToString()
# 对已经序列化的数据进行反序列化
target = person_pb2.all_person()
target.ParseFromString(data)
print(target.Per[1].name) # 打印第一个 person name 的值进行反序列化验证
上一篇: Python中的finally
下一篇: python 第三方模块
47848
46401
37288
34737
29319
25976
24920
19954
19549
18032
5795°
6419°
5935°
5964°
7070°
5918°
5949°
6442°
6405°
7783°