飘逸的python - 使用protocal buffers

protocol buffers是google提供的一种将结构化数据进行序列化和反序列化的方法,多用于通讯协议。本文简单介绍一下在python中如何使用pb。
几个步骤

  • 下载Protocol Buffers compiler,下载地址 https://protobuf.googlecode.com/files/protoc-2.5.0-win32.zip ,解压出来得到protoc.exe
  • 使用easy_install或pip安装python库protobuf
  • 编写proto文件
  • 使用protoc.exe对proto文件进行编译,生成python文件 (格式:protoc.exe -I=$SRC_DIR --python_out=$DST_DIR $SRC_DIR/xxx.proto)
  • 然后就可以在python中import进去使用了
下面举个栗子
下载得到了protoc.exe之后,丢进c:\Windows\System32\,因为这个目录在环境变量里面,这样就可以在cmd直接运行protoc命令。
编写user.proto文件

package user;
message Person {
  required string name = 1;
  required int32 id = 2;
  optional string email = 3;
}

使用protoc进行编译,d:\>protoc -I=d:\ --python_out=d:\ d:\user.proto,不知道各位看官发现了没有,编译给python用的就用--python_out参数,编译给其它语言用的请自行脑补。
编译后得到文件user_pb2.py。
在程序中对user_pb2进行调用。

#coding=utf-8
import user_pb2
person1 = user_pb2.Person()
person1.id = 160824
person1.name = u"打怪的程序猿"
person1.email = "160824@qq.com"

person_serial = person1.SerializeToString()#进行序列化
print person_serial#序列化后的字符串
print '------------'

person2 = user_pb2.Person()
person2.ParseFromString(person_serial)#进行反序列化
#print person2
print person2.id
print person2.name
print person2.email

其中最主要的2个方法就是SerializeToString()和ParseFromString(),类似于json的dumps()和loads()。
输出:


  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值