Python 序列化之 ProtoBuf - Go语言中文社区

Python 序列化之 ProtoBuf


ProtoBuf: 是一套完整的 IDL(接口描述语言),出自Google,基于 C++ 进行的实现,开发人员可以根据 ProtoBuf 的语言规范生成多种编程语言(Golang、Python、Java 等)的接口代码,本篇只讲述 Python 的基础操作。据说 ProtoBuf 所生成的二进制文件在存储效率上比 XML 高 3~10 倍,并且处理性能高 1~2 个数量级,这也是选择 ProtoBuf 作为序列化方案的一个重要因素之一。

安装:

  1. 安装 protoc :Protoc下载地址,可以根据自己的系统下载相应的 protoc,windows 用户统一下载 win32 版本。
  2. 配置 protoc 到系统的环境变量中,执行如下命令查看是否安装成功:

    $ protoc –version
    如果正常打印 libprotoc 的版本信息就表明 protoc 安装成功

  3. 安装 ProtoBuf 相关的 python 依赖库

    $ pip install protobuf

使用

  1. 创建 demo python 工程
    Paste_Image.png

  2. 在 example 包中编写 person.proto

    syntax = "proto3";
    package example;
    
    message person {   
        int32 id = 1;
        string name = 2;
    }
    
    message all_person {    
        repeated person Per = 1;
    }
  3. 进入 demo 工程的 example 目录,使用 protoc 编译 person.proto

    $ protoc –python_out=. person.proto
    就会生成 person.pb2.py 文件

  4. 在 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 扫码入群:

qq群.jpg

版权声明:本文来源CSDN,感谢博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/CoderInfo/article/details/60604416
站方申明:本站部分内容来自社区用户分享,若涉及侵权,请联系站方删除。
  • 发表于 2020-02-02 18:26:03
  • 阅读 ( 1516 )
  • 分类:

0 条评论

请先 登录 后评论

官方社群

GO教程

推荐文章

猜你喜欢