Python 序列化之 ProtoBuf
来源:互联网 发布:mac如何删除word软件 编辑:程序博客网 时间:2024/06/02 02:23
ProtoBuf: 是一套完整的 IDL(接口描述语言),出自Google,基于 C++ 进行的实现,开发人员可以根据 ProtoBuf 的语言规范生成多种编程语言(Golang、Python、Java 等)的接口代码,本篇只讲述 Python 的基础操作。据说 ProtoBuf 所生成的二进制文件在存储效率上比 XML 高 3~10 倍,并且处理性能高 1~2 个数量级,这也是选择 ProtoBuf 作为序列化方案的一个重要因素之一。
安装:
- 安装 protoc :Protoc下载地址,可以根据自己的系统下载相应的 protoc,windows 用户统一下载 win32 版本。
配置 protoc 到系统的环境变量中,执行如下命令查看是否安装成功:
$ protoc –version
如果正常打印 libprotoc 的版本信息就表明 protoc 安装成功安装 ProtoBuf 相关的 python 依赖库
$ pip install protobuf
使用
创建 demo python 工程
在 example 包中编写 person.proto
syntax = "proto3";package example;message person { int32 id = 1; string name = 2;}message all_person { repeated person Per = 1;}
进入 demo 工程的 example 目录,使用 protoc 编译 person.proto
$ protoc –python_out=. person.proto
就会生成 person.pb2.py 文件- 在 python 工程中使用 protobuf 进行序列化与反序列化
main.py:
#! /usr/bin/env python # -*- coding: utf-8 -*- from example import person_pb2 # 为 all_person 填充数据 pers = person_pb2.all_person() p1 = pers.Per.add() p1.id = 1 p1.name = 'xieyanke' p2 = pers.Per.add() p2.id = 2 p2.name = 'pythoner' # 对数据进行序列化 data = pers.SerializeToString() # 对已经序列化的数据进行反序列化 target = person_pb2.all_person() target.ParseFromString(data) print(target.Per[1].name) # 打印第一个 person name 的值进行反序列化验证
- 进一步交流可以加 QQ 群:397234385
- 或者 QQ 扫码入群:
8 0
- Python 序列化之 ProtoBuf
- 网络-数据序列化之protobuf
- 网络-数据序列化之protobuf
- 分布式通讯-序列化之protobuf
- Protobuf序列化协议
- protobuf序列化存储
- protobuf (序列化协议)
- 序列化protobuf
- protobuf序列化原理
- NetworkComms V3 序列化器之Protobuf.net和 JSONSerializer
- 序列化之protobuf与avro对比(Java)
- Python之序列化
- Jackson--protobuf序列化积累
- C# Protobuf-Net 序列化
- google protobuf序列化原理
- Protobuf 序列化协议详解
- google protobuf序列化原理
- python学习之序列化
- Maximum Subsequence Sum
- 面向对象的基本概念
- 机器学习算法总结
- 简单dp,first wrong POJ 3616 Milking Time
- 排序--3.选择
- Python 序列化之 ProtoBuf
- 将一个数组拆分成两个数组,两个数组的差的绝对值最小
- Linux命令(一)
- 九度OJ-1103:二次方程计算器
- C++ 学习之旅
- Good morning [字符串]
- 浅谈物理地址、虚拟地址和逻辑地址
- 51单片机的IO端口
- todolistl