91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python如何實現序列化和反序列化

發布時間:2022-02-21 10:02:08 來源:億速云 閱讀:210 作者:iii 欄目:開發技術

本文小編為大家詳細介紹“Python如何實現序列化和反序列化”,內容詳細,步驟清晰,細節處理妥當,希望這篇“Python如何實現序列化和反序列化”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。

我們前后端進行交互的時候可以使用JSON進行交互,但是python應用和python應用之間如果使用JSON來傳遞數據是一種浪費的行為(JSON傳遞的信息有限)這個時候我們可以通過protobuf庫來將python對象序列化,然后變成二進制數據傳輸,最后再進行python反序列化得到這個對象。

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如何實現序列化和反序列化”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

台州市| 长顺县| 吉林省| 眉山市| 台北县| 友谊县| 申扎县| 开平市| 元氏县| 巴南区| 婺源县| 宕昌县| 杨浦区| 巴青县| 乌鲁木齐市| 文成县| 宣汉县| 白银市| 宁海县| 安福县| 泰和县| 九台市| 无极县| 高邑县| 两当县| 嵩明县| 南召县| 抚顺市| 阿克苏市| 调兵山市| 舞阳县| 上虞市| 江津市| 静乐县| 资中县| 原平市| 文昌市| 隆林| 许昌县| 纳雍县| 新沂市|