Python使用protobuf序列化和反序列化的实现


Posted in Python onMay 19, 2021

protobuf介绍

protobuf是一种二进制的序列化格式,相对于json来说体积更小,传输更快。

安装protobuf

安装protobuf的目的主要用来将proto文件编译成python、c、Java可调用的接口。

# 如果gcc版本较低,需要升级gcc
wget https://main.qcloudimg.com/raw/d7810aaf8b3073fbbc9d4049c21532aa/protobuf-2.6.1.tar.gz
tar -zxvf protobuf-2.6.1.tar.gz -C /usr/local/ && cd /usr/local/protobuf-2.6.1
./configure 
make && make install
# 可以在/etc/profile或者~/.bash_profile末尾设置永久有效
export PATH=$PATH:/usr/local/protobuf-2.6.1/bin

使用下面命令查看是否安装成功。

[root@CodeOnTheRoad ~]# protoc --version
libprotoc 2.6.1

构建python接口

创建cls.proto文件,定义序列化结构:

package cls;

message Log
{
    message Content
    {
        required string key   = 1; // 每组字段的 key
        required string value = 2; // 每组字段的 value
    }
    required int64   time     = 1; // 时间戳,UNIX时间格式
    repeated Content contents = 2; // 一条日志里的多个kv组合
}

message LogTag
{
    required string key       = 1;
    required string value     = 2;
}

message LogGroup
{
    repeated Log    logs        = 1; // 多条日志合成的日志数组
    optional string contextFlow = 2; // 目前暂无效用
    optional string filename    = 3; // 日志文件名
    optional string source      = 4; // 日志来源,一般使用机器IP
    repeated LogTag logTags     = 5;
}

message LogGroupList
{
    repeated LogGroup logGroupList = 1; // 日志组列表
}

只用下面命令将proto文件转换为python可调用的接口。

protoc cls.proto --python_out=./

执行完后,在此目录下生成cls_pb2.py。

序列化

import cls_pb2 as cls
import time

# 构建protoBuf日志内容
LogLogGroupList = cls.LogGroupList()

LogGroup = LogLogGroupList.logGroupList.add()
LogGroup.contextFlow = "1"
LogGroup.filename = "python.log"
LogGroup.source = "localhost"

LogTag = LogGroup.logTags.add()
LogTag.key = "key"
LogTag.value = "value"

Log = LogGroup.logs.add()
Log.time = int(round(time.time() * 1000000))

Content = Log.contents.add()
Content.key = "Hello"
Content.value = "World"
print(LogLogGroupList)
# 序列化
data = LogLogGroupList.SerializeToString()
print(data)

其实就是讲一个protobuf的结构文本序列化成了二进制的形式。

反序列化

反序列化就是将二进制转换成protobuf结构。

# 反序列化
LogLogGroupList = cls.LogGroupList()
LogLogGroupList.ParseFromString(data)
print(LogLogGroupList)

运行结果

上面序列化和反序列化代码结果运行如下:

Python使用protobuf序列化和反序列化的实现

到此这篇关于Python使用protobuf序列化和反序列化的实现的文章就介绍到这了,更多相关Python 序列化和反序列化内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
使用Python获取CPU、内存和硬盘等windowns系统信息的2个例子
Apr 15 Python
Python实现的简单万年历例子分享
Apr 25 Python
Python类的专用方法实例分析
Jan 09 Python
Python+Opencv识别两张相似图片
Mar 23 Python
Python列表切片用法示例
Apr 19 Python
彻底搞懂Python字符编码
Jan 23 Python
[原创]Python入门教程2. 字符串基本操作【运算、格式化输出、常用函数】
Oct 29 Python
python将list转为matrix的方法
Dec 12 Python
对Python 检查文件名是否规范的实例详解
Jun 10 Python
python获取引用对象的个数方式
Dec 20 Python
python实现企业微信定时发送文本消息的示例代码
Nov 24 Python
使用python向MongoDB插入时间字段的操作
May 18 Python
详解分布式系统中如何用python实现Paxos
May 18 #Python
如何在向量化NumPy数组上进行移动窗口
Python如何配置环境变量详解
Python打包为exe详细教程
Python基础之数据类型知识汇总
May 18 #Python
Python实战之疫苗研发情况可视化
Python打包exe时各种异常处理方案总结
You might like
给apache2.2加上mod_encoding模块後 php5.2.0 处理url出现bug
2007/04/12 PHP
php下将XML转换为数组
2010/01/01 PHP
Yii2 queue的队列使用详解
2019/07/19 PHP
javascript 学习笔记(八)javascript对象
2011/04/12 Javascript
简单的jquery拖拽排序效果实现代码
2011/09/20 Javascript
利用jquery的获取JS文件中的字符串内容
2012/02/14 Javascript
JS动态添加option和删除option(附实例代码)
2013/04/01 Javascript
jquery动态分页效果堪比时光网
2014/09/25 Javascript
angularJS中router的使用指南
2015/02/09 Javascript
JSONObject使用方法详解
2015/12/17 Javascript
javascript实现简单的全选和反选功能
2016/01/05 Javascript
微信小程序 触控事件详细介绍
2016/10/17 Javascript
React实践之Tree组件的使用方法
2017/09/30 Javascript
解决vue打包项目后刷新404的问题
2018/03/06 Javascript
Vue-router的使用和出现空白页,路由对象属性详解
2018/09/03 Javascript
vue弹窗组件的实现示例代码
2018/09/10 Javascript
Vue路由之JWT身份认证的实现方法
2019/08/26 Javascript
构建一个JavaScript插件系统
2020/10/20 Javascript
[28:28]Ti4 冒泡赛第二天NEWBEE vs NaVi 2
2014/07/15 DOTA
[00:36]DOTA2上海特级锦标赛 LGD战队宣传片
2016/03/04 DOTA
Python字符串逐字符或逐词反转方法
2015/05/21 Python
Python 专题二 条件语句和循环语句的基础知识
2017/03/19 Python
深入理解Python爬虫代理池服务
2018/02/28 Python
TensorFlow搭建神经网络最佳实践
2018/03/09 Python
python 日志模块logging的使用场景及示例
2021/01/04 Python
美国知名户外用品畅销中心:Sierra Trading Post
2016/07/19 全球购物
Clearly新西兰:购买眼镜、太阳镜和隐形眼镜
2018/04/26 全球购物
新浪微博实习心得体会
2014/01/27 职场文书
小学开学典礼主持词
2014/03/19 职场文书
优秀学生党员先进事迹材料
2014/05/29 职场文书
违反交通法规检讨书
2014/09/10 职场文书
教师作风整改措施思想汇报
2014/10/12 职场文书
违纪检讨书范文
2015/01/27 职场文书
2015年社区党建工作汇报材料
2015/06/25 职场文书
导游词之藏龙百瀑景区
2019/12/30 职场文书
golang中切片copy复制和等号复制的区别介绍
2021/04/27 Golang