飘逸的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文件
使用protoc进行编译,d:\>protoc -I=d:\ --python_out=d:\ d:\user.proto,不知道各位看官发现了没有,编译给python用的就用--python_out参数,编译给其它语言用的请自行脑补。
编译后得到文件user_pb2.py。
在程序中对user_pb2进行调用。
其中最主要的2个方法就是SerializeToString()和ParseFromString(),类似于json的dumps()和loads()。
输出:
几个步骤:
下载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()。
输出:
相关文章推荐
- 飘逸的python - 使用reload进行热更新
- 飘逸的python - 使用traceback获取详细的异常信息
- 飘逸的python - 使用dis模块进行代码层次的性能剖析
- 飘逸的python - 不使用keyword,求和1+2+…+n
- 飘逸的python - 使用图像匹配SIFT算法进行LOGO检测
- 飘逸的python - 使用dis模块进行代码层次的性能剖析
- 飘逸的python - 不使用关键字,求和1+2+…+n
- 飘逸的python - 使用reload进行热更新
- python 图 自身遍历 及弱引用使用
- python使用time、datetime返回工作日列表
- 使用Python Selenium PhantomJS的XPath时应注意校验结果
- 从变量到封装:一文带你为机器学习打下坚实的Python基础 By 机器之心2017年10月13日 10:43 本文整体梳理了 Python 的基本语法与使用方法,并重点介绍了对机器学习十分重要的且常
- Python 爬虫实战(一):使用 requests 和 BeautifulSoup
- Python爬虫系列之----Scrapy使用IP代理池
- Python从使用线程到使用async/await的深入讲解
- python操作Excel读写--使用xlrd
- 如何使用linux下gdb来调试python程序
- Python 使用sqlite3
- python工具使用之pip安装
- Python optionParser模块的使用方法