午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術文章
文章詳情頁

Python使用protobuf序列化和反序列化的實現

瀏覽:13日期:2022-06-19 10:53:12
protobuf介紹

protobuf是一種二進制的序列化格式,相對于json來說體積更小,傳輸更快。

安裝protobuf

安裝protobuf的目的主要用來將proto文件編譯成python、c、Java可調用的接口。

# 如果gcc版本較低,需要升級gccwget https://main.qcloudimg.com/raw/d7810aaf8b3073fbbc9d4049c21532aa/protobuf-2.6.1.tar.gztar -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 --versionlibprotoc 2.6.1構建python接口

創建cls.proto文件,定義序列化結構:

package cls;message Log{ message Content {required string key = 1; // 每組字段的 keyrequired 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 clsimport 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 編程
相關文章:
主站蜘蛛池模板: 亚洲在线免费观看 | 国产51页 | 免费成年人视频 | 在线观看国产成人 | 三级三级久久三级久久18 | 亚洲影院在线 | 福利精品 | 91免费国产视频 | 国产精品99久久久久 | 青春草av | 日本黄色高清视频 | gogogo免费高清日本写真 | 99国产精品久久久久 | 国产高清一区二区三区四区 | 国产一区,二区 | 黄色一级大片在线免费看国产一 | zjzjzjzjzj亚洲女人 | 黄色a网站 | 日韩av成人在线观看 | 欧美日韩看片 | 五月婷婷国产 | 成人免费影院 | 欧美成人一级片 | 久久av一区二区三区亚洲 | 免费黄色一级片 | av在线成人| 在线成人免费视频 | 中国毛片在线观看 | 欧美日韩一区三区 | 青青草日本 | 福利在线免费视频 | 色天天干| av三级| 日韩中文字幕免费视频 | www.日韩在线| 欧美日韩精品久久久免费观看 | 好了av在线 | 国产99久久久 | 亚洲 美腿 欧美 偷拍 | 中文字幕在线高清 | 日本91|