如何在mac环境中用python处理protobuf


Posted in Python onDecember 25, 2019

这篇文章主要介绍了如何在mac环境中用python处理protobuf,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

安装

brew install protobuf

然后再安装protobuf需要的依赖

brew install autoconf automake libtool

验证是否安装成功

protoc ?version

protobuf3语法介绍

1.字段前取消了required和optional两个关键字,目前可用的只有repeated关键字。

2.不可以现设置默认值了。

a.string默认为空串

b.枚举默认为第一个枚举定义的第一个值。并且必须是0,必须有有一个0值,我们可以用这个0值作为默认值。
这个零值必须为第一个元素,为了兼容proto2语义,枚举类的第一个值总是默认值。

c.bytes默认为空bytes

d.bool默认为false

e.数字类型默认为0

3.protoType类型如下:

double、float、int32、int64、uint32、uint64、sint32、sint64、fixed32、fixed64、sfixed32、sfixed64、bool、string、bytes

4、分配标识号

正如你所见,在消息定义中,每个字段都有唯一的一个数字标识符。这些标识符是用来在消息的二进制格式中识别各个字段的,一旦开始使用就不能够再改变。注:[1,15]之内的标识号在编码的时候会占用一个字节。[16,2047]之内的标识号则占用2个字节。所以应该为那些频繁出现的消息元素保留 [1,15]之内的标识号。切记:要为将来有可能添加的、频繁出现的标识号预留一些标识号。

最小的标识号可以从1开始,最大到2^29 - 1, or 536,870,911。不可以使用其中的[19000-19999]( (从FieldDescriptor::kFirstReservedNumber 到 FieldDescriptor::kLastReservedNumber))的标识号, Protobuf协议实现中对这些进行了预留。如果非要在.proto文件中使用这些预留标识号,编译时就会报警。同样你也不能使用早期保留的标识号。

指定字段规则

所指定的消息字段修饰符必须是如下之一:

  • singular:一个格式良好的消息应该有0个或者1个这种字段(但是不能超过1个)。
  • repeated:在一个格式良好的消息中,这种字段可以重复任意多次(包括0次)。重复的值的顺序会被保留。

在proto3中,repeated的标量域默认情况虾使用packed。

编写protoco文件,addressbook.proto。

syntax = "proto3"; //正在使用proto3语法,如果你没有指定这个,编译器会使用proto2
package tutorial;

//*.proto文件中数据类型可以分为两大类:
//复合数据类型包括:枚举和message类型
//标准数据类型包含:整型,浮点,字符串等

message AddressBook {
 //repeated: 该字段可以重复任意次数,包括0次。重复数据的顺序将会保存在protocol buffer中,将这个字段想象成一个可以自动设置size的数组就可以了。
 repeated Person people = 1;
}

message Person {
 //每个字段有一种类型
 //该Number是用来标记该字段在序列化后的二进制数据中所在的field,
 //每个字段的Number在message内部都是独一无二的。也不能进行改变,否则数据就不能正确的解包
 string name = 1;
 int32 id = 2;
 string email = 3;
 float money =4;
 bool work_status = 5;
 repeated PhoneNumber phones =6;
 MyMessage maps =7;
}
message PhoneNumber{
   string number =1;
   PhoneType type =2;
}

enum PhoneType{
  MOBILE =0;
  HOME =1;
  WORK =2;

}

message MyMessage{
  map<int32,int32> mapfield =1;
}

编译生成python代码

protoc ./addressbook.proto --python_out=./

创建一个解析文件

protobufdemo.py

# -*- coding: utf-8 -*-
# @Time : 2019-11-15 11:25
# @Author : cxa
# @File : protobufdemo.py
# @Software: PyCharm
import addressbook_pb2

address_book = addressbook_pb2.AddressBook()
person = address_book.people.add()
person.id = 1
person.name = "cxa"
person.email = "1@qq.com"
person.money = 1234.00
person.work_status = True

phone_number = person.phones.add()
phone_number.number = "123456"
phone_number.type = addressbook_pb2.MOBILE
maps = person.maps
maps.mapfield[1] = 1
maps.mapfield[2] = 2

# 序列化
serializeTostring = address_book.SerializeToString() # 生成字节数组
str_result = address_book.ParseFromString(serializeTostring) # 转为字符串
print(str_result)
for person in address_book.people:
  print(person)

for phone_number in person.phones:
  print(phone_number)

for key in person.maps.mapfield:
  print(key, person.maps.mapfield[key])

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python解析树及树的遍历
Feb 03 Python
shelve  用来持久化任意的Python对象实例代码
Oct 12 Python
Python 描述符(Descriptor)入门
Nov 20 Python
python 识别图片中的文字信息方法
May 10 Python
python发送告警邮件脚本
Sep 17 Python
快速排序的四种python实现(推荐)
Apr 03 Python
浅谈Pytorch中的torch.gather函数的含义
Aug 18 Python
Python 矩阵转置的几种方法小结
Dec 02 Python
python实现批量命名照片
Jun 18 Python
python opencv实现简易画图板
Aug 27 Python
基于python实现百度语音识别和图灵对话
Nov 02 Python
教你如何使用Python开发一个钉钉群应答机器人
Jun 21 Python
Python Print实现在输出中插入变量的例子
Dec 25 #Python
django数据模型(Model)的字段类型解析
Dec 25 #Python
python装饰器的特性原理详解
Dec 25 #Python
Python将列表中的元素转化为数字并排序的示例
Dec 25 #Python
python中的subprocess.Popen()使用详解
Dec 25 #Python
python打印n位数“水仙花数”(实例代码)
Dec 25 #Python
python中有关时间日期格式转换问题
Dec 25 #Python
You might like
thinkPHP简单调用函数与类库的方法
2017/03/15 PHP
Kindeditor编辑器添加图片上传水印功能(php代码)
2017/08/03 PHP
PHP实现基于回溯法求解迷宫问题的方法详解
2017/08/17 PHP
LBS blog sql注射漏洞[All version]-官方已有补丁
2007/08/26 Javascript
ExtJS判断IE浏览器类型的方法
2014/02/10 Javascript
jquery设置按钮停顿3秒不可用
2014/03/07 Javascript
js 3秒后跳转页面的实现代码
2014/03/10 Javascript
Knockout自定义绑定创建方法
2015/12/26 Javascript
JS仿JQuery选择器功能
2017/03/08 Javascript
Vue中的v-cloak使用解读
2017/03/27 Javascript
Jquery中attr与prop的区别详解
2017/05/27 jQuery
浅谈关于iview表单验证的问题
2018/09/29 Javascript
创建Vue项目以及引入Iview的方法示例
2018/12/03 Javascript
JQuery插件tablesorter表格排序实现过程解析
2020/05/28 jQuery
[01:10]DOTA2英雄背景故事第四期之混沌法则混沌骑士
2020/07/16 DOTA
python利用beautifulSoup实现爬虫
2014/09/29 Python
python实现爬取图书封面
2018/07/05 Python
使用Python读取二进制文件的实例讲解
2018/07/09 Python
python pygame模块编写飞机大战
2018/11/20 Python
在Python中,不用while和for循环遍历列表的实例
2019/02/20 Python
使用Pyinstaller转换.py文件为.exe可执行程序过程详解
2019/08/06 Python
pytorch中的上采样以及各种反操作,求逆操作详解
2020/01/03 Python
Python 如何批量更新已安装的库
2020/05/26 Python
Python reques接口测试框架实现代码
2020/07/28 Python
Python面向对象多态实现原理及代码实例
2020/09/16 Python
StubHub意大利:购买和出售全球演唱会和体育赛事门票
2017/11/21 全球购物
e路東瀛(JAPANiCAN)香港:日本旅游、日本酒店和温泉旅馆预订
2018/11/21 全球购物
美国名表在线商城:Ashford(支持中文)
2019/09/24 全球购物
英国在线滑雪板和冲浪商店:The Board Basement
2020/01/11 全球购物
会计专业毕业生自荐书
2014/06/25 职场文书
中药学专业毕业生推荐信
2014/07/10 职场文书
税务干部群众路线教育实践活动自我剖析材料
2014/09/21 职场文书
违章停车检讨书
2014/10/21 职场文书
怎样写好工作计划
2019/04/10 职场文书
Python爬虫进阶之Beautiful Soup库详解
2021/04/29 Python
Java org.w3c.dom.Document 类方法引用报错
2021/08/07 Java/Android