Google Protocol Bufferのインストールとpythonでの使用

4664 ワード

インストール
1.protobufソースコードのダウンロード(現在の最新バージョン:2.5.0)#cd/opt#wgethttps://protobuf.googlecode.com/files/protobuf-2.5.0.tar.gz
2.解凍、コンパイル、インストール#tar zxvf protobuf-2.5.0.tar.gz  #cd protobuf-2.5.0  #./configure --prefix=/home/xxx/app/protobuf#make  #make check  #make install
3.protobufのpythonモジュールのインストールを続行します(pythonを使用しない場合は、このステップをスキップできます)#cd./python  #python setup.py build  #python setup.py test  #python setup.py install
4.環境変数の追加
export PATH=$PATH:
/home/xxx/app/protobuf/bin
export PKG_CONFIG_PATH=
/home/xxx/app/protobuf/lib/pkgconfig/
実行の保存
source/etc/profile
5.インストール完了、Linuxコマンド#protoc–versionの検証
6.Pythonモジュールが正しくインストールされているかどうかを確認します.protobufエラーが報告されていない場合は、インストールが正常であることを示します.
Note:
error: package directory 'google/protobuf/compiler' does not exist
解決策:google/protobuf/でcompilerフォルダを作成する
protobufフォルダで再度実行:python setup.py install
使用
protoファイルpackage lmを書く;  message Person  {          required int32  id = 1;          required string str = 2;          optional int32  opt = 3;}testpとして保存する.testpb.protoコンパイル命令protoc-I=/home/workspace/testprob--python_out=/home/workspace/testprob/home/workspace/testprob/testp.testpb.proto 
  -I source   ,--python_out    python      ,      proto  。  ,pb   c++ java,  --python_out  。

google
 
https://developers.google.com/protocol-buffers/docs/pythontutorial
 
誤報
 
package directory 'google/protobuf/compiler' does not exist
 
解決する
 
https://groups.google.com/forum/?fromgroups=#!topic/protobuf/YeT5RW4qCxY
 
python ./setup.py build
 
sudo python ./setup.py install
 
誤報
 
 File "/home/workspace/testprob/testp/testpb_pb2.py", line 6, in
 
    from google.protobuf import reflection as _reflection
 
  File "build/bdist.linux-i686/egg/google/protobuf/reflection.py", line 68, in
 
  File "build/bdist.linux-i686/egg/google/protobuf/internal/python_message.py"
 
  ImportError: cannot import name enum_type_wrapper
 
解決する
 
http://code.google.com/p/protobuf/issues/detail?id=438
 
Log message
 
Fix  issue 438 : add missing 'enum_type_wrapper' to setup.py
 
インストールパッケージの改良ファイルです.copyを降りて、再インストールします.
 
インストールディレクトリの下のdemoによって自分で簡単に書き換えましたが、それはやはり面倒だと思います.
 
write.py
 
import testpb_pb4
 
import sys
 
p = testpb_pb2.Person()
 
try:
 
  f = open(sys.argv[1], "rb")
 
  p.ParseFromString(f.read())
 
  f.close()
 
except IOError:
 
  print sys.argv[1] + ": File not found.  Creating a new file."
 
p.id = 32
 
p.str = "test"
 
f = open(sys.argv[1], "wb")
 
f.write(p.SerializeToString())
 
f.close()
 
print "write success"
 
コンパイル命令python write.py "test"
 
read.py 
 
import sys
 
import testpb_pb2
 
if len(sys.argv) != 2:
 
  print "Usage:", sys.argv[0], "ADDRESS_BOOK_FILE"
 
  sys.exit(-1)
 
p = testpb_pb2.Person()
 
f = open(sys.argv[1], "rb")
 
p.ParseFromString(f.read())
 
f.close()
 
print "p.str = ",  p.str
 
print "p.id=", p.id
 
コンパイル命令python read.py "test"
Protobufは、基本データ型のセットを定義します.ほとんどC+Javaなどの言語の基礎データ型にマッピングできる.
      
protobufデータ型
説明
梱包する
C++言語マッピング
bool
ブール型
1バイト
bool
double
64ビット浮動小数点数
N
double
float
32は浮動小数点数
N
float
int32
32ビット整数、
N
int
uint32
符号なし32ビット整数
N
unsigned int
int64
64ビット整数
N
__int64
uint64
64は符号なし
N
unsigned __int64
sint32
32ビット整数、負数処理効率が向上
N
int32
sing64
64ビット整数処理の負数効率が向上
N
__int64
fixed32
32ビット符号なし整数
4
unsigned int32
fixed64
64ビット符号なし整数
8
unsigned __int64
sfixed32
32ビット整数、負の数をより効率的に処理
4
unsigned int32
sfixed64
64は整数
8
unsigned __int64
string
ASCII文字のみの処理
N
std::string
bytes
中国語などのマルチバイトを処理する言語文字
N
std::string
enum
ユーザー定義の列挙タイプuint 32を含めることができます
N
enum
message
ユーザー定義のメッセージ・タイプを含めることができます
N
object of class