您的位置:首页 > 编程语言 > Python开发

飘逸的python - 使用protocal buffers

2013-12-22 14:12 323 查看
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()。

输出:

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: