濮阳杆衣贸易有限公司

主頁 > 知識庫 > Python使用protobuf序列化和反序列化的實現(xiàn)

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

熱門標簽:外呼系統(tǒng)哪些好辦 沈陽人工外呼系統(tǒng)價格 如何申請400電話費用 沈陽外呼系統(tǒng)呼叫系統(tǒng) 沈陽防封電銷卡品牌 富錦商家地圖標注 池州外呼調研線路 武漢外呼系統(tǒng)平臺 江西省地圖標注

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接口

創(chuàng)建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; // 多條日志合成的日志數(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文件轉換為python可調用的接口。

protoc cls.proto --python_out=./ 

執(zhí)行完后,在此目錄下生成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序列化和反序列化的實現(xiàn)的文章就介紹到這了,更多相關Python 序列化和反序列化內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • java程序中protobuf的基本用法示例
  • 淺談序列化之protobuf與avro對比(Java)
  • 基于Protobuf動態(tài)解析在Java中的應用 包含例子程序
  • protobuf c++編程筆記
  • python使用protobufde的過程解析
  • SpringBoot使用protobuf格式的接口方式
  • Netty結合Protobuf進行編解碼的方法
  • Protobuf在Cmake中的正確使用方法詳解
  • C#語言使用gRPC、protobuf(Google Protocol Buffers)實現(xiàn)文件傳輸功能
  • 在java程序中使用protobuf

標簽:株洲 黑龍江 潛江 銅川 阿里 通遼 呂梁 常德

巨人網(wǎng)絡通訊聲明:本文標題《Python使用protobuf序列化和反序列化的實現(xiàn)》,本文關鍵詞  Python,使用,protobuf,序列化,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Python使用protobuf序列化和反序列化的實現(xiàn)》相關的同類信息!
  • 本頁收集關于Python使用protobuf序列化和反序列化的實現(xiàn)的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    新民市| 石泉县| 大田县| 广平县| 贵阳市| 达州市| 双江| 汉沽区| 南澳县| 汾阳市| 菏泽市| 庄河市| 普定县| 龙陵县| 河北区| 措美县| 永嘉县| 呼和浩特市| 郴州市| 米易县| 怀仁县| 海口市| 阆中市| 桂东县| 江达县| 汝南县| 馆陶县| 金寨县| 琼结县| 沾益县| 五常市| 武定县| 鹤山市| 肃北| 郯城县| 浏阳市| 视频| 谷城县| 重庆市| 邮箱| 东宁县|