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
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
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 。
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