人妖在线一区,国产日韩欧美一区二区综合在线,国产啪精品视频网站免费,欧美内射深插日本少妇

新聞動態(tài)

Python使用protobuf序列化和反序列化的實現(xiàn)

發(fā)布日期:2022-06-14 14:41 | 文章來源:站長之家

protobuf介紹

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

安裝protobuf

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

# 如果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末尾設(shè)置永久有效
export PATH=$PATH:/usr/local/protobuf-2.6.1/bin

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

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

構(gòu)建python接口

創(chuàng)建cls.proto文件,定義序列化結(jié)構(gòu):

package cls;
message Log
{
 message Content
 {
  required string key= 1; // 每組字段的 key
  required string value = 2; // 每組字段的 value
 }
 required int64time  = 1; // 時間戳,UNIX時間格式
 repeated Content contents = 2; // 一條日志里的多個kv組合
}
message LogTag
{
 required string key = 1;
 required string value  = 2;
}
message LogGroup
{
 repeated Log logs  = 1; // 多條日志合成的日志數(shù)組
 optional string contextFlow = 2; // 目前暫無效用
 optional string filename = 3; // 日志文件名
 optional string source= 4; // 日志來源,一般使用機器IP
 repeated LogTag logTags  = 5;
}
message LogGroupList
{
 repeated LogGroup logGroupList = 1; // 日志組列表
}
 

只用下面命令將proto文件轉(zhuǎn)換為python可調(diào)用的接口。

protoc cls.proto --python_out=./ 

執(zhí)行完后,在此目錄下生成cls_pb2.py。

序列化

import cls_pb2 as cls
import time
# 構(gòu)建protoBuf日志內(nèi)容
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的結(jié)構(gòu)文本序列化成了二進制的形式。

反序列化

反序列化就是將二進制轉(zhuǎn)換成protobuf結(jié)構(gòu)。

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

運行結(jié)果

上面序列化和反序列化代碼結(jié)果運行如下:

到此這篇關(guān)于Python使用protobuf序列化和反序列化的實現(xiàn)的文章就介紹到這了,更多相關(guān)Python 序列化和反序列化內(nèi)容請搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!

美國服務(wù)器租用

版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。

相關(guān)文章

實時開通

自選配置、實時開通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問服務(wù)

1對1客戶咨詢顧問

在線
客服

在線客服:7*24小時在線

客服
熱線

400-630-3752
7*24小時客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部