Yet another tool that compiles .proto strings and import the outcome Python modules.
Project description
A Python package that
- takes a
str
containing protobuf messages definitions - returns a
types.ModuleType
instance
It is useful for programs needing to en/decode protobuf messages for which the definition is provided as a string at runtime.
Installation
pip install proto-topy
Prerequisite: proto-topy
needs protoc to be installed. On macOS, a simple brew install protobuf
shall suffice.
single proto example: address book
Adaptation of the protocolbuffers
example:
import requests
from pathlib import Path
from proto_topy import ProtoModule
# Retrieve protobuf messages definitions as a string
example_source = requests.get(
"https://raw.githubusercontent.com/protocolbuffers/protobuf/main/"
"examples/addressbook.proto").text
example_path = Path(
"protocolbuffers/protobuf/blob/main/examples/addressbook.proto")
# Compile and import
module = ProtoModule(file_path=example_path, source=example_source).compiled()
# Produce a serialized address book
address_book = module.py.AddressBook()
person = address_book.people.add()
person.id = 111
person.name = "A Name"
person.email = "a.name@mail.com"
phone_number = person.phones.add()
phone_number.number = "+1234567"
phone_number.type = module.py.Person.MOBILE
with open("address_book.data", "wb") as o:
o.write(address_book.SerializeToString())
# Use a serialized address book
address_book = module.py.AddressBook()
with open("address_book.data", "rb") as i:
address_book.ParseFromString(i.read())
for person in address_book.people:
print(person.id, person.name, person.email, phone_number.number)
multiple protos example
When several .proto
need to be considered, use a ProtoCollection
:
import sys
from pathlib import Path
from proto_topy import ProtoModule, ProtoCollection
module1 = ProtoModule(
file_path=Path("p1/p2/other2.proto"),
source="""
syntax = "proto3";
import "google/protobuf/timestamp.proto";
message OtherThing2 {
google.protobuf.Timestamp created = 1;
};"""
)
module2 = ProtoModule(
file_path=Path("p3/p4/test6.proto"),
source="""
syntax = "proto3";
import "p1/p2/other2.proto";
message Test6 {
OtherThing2 foo = 1;
};"""
)
collection = ProtoCollection(module1, module2).compiled()
sys.modules.update({proto.name: proto.py
for proto in collection.modules.values()})
print(sys.modules['test6'].Test6,
sys.modules['other2'].OtherThing2)
Stream of delimited messages
To decode a stream of contiguous protobuf messages of the same type, use DelimitedMessageFactory
. Example:
from io import BytesIO
from pathlib import Path
from proto_topy import ProtoModule, DelimitedMessageFactory
# Generate Python module
module = ProtoModule(
file_path=Path("int32_streams.proto"),
source="""
syntax = "proto3";
message TestInt { int32 val = 1; };"""
).compiled()
# Feed a DelimitedMessageFactory with a sequence of TestInt instances for a range of 10 ints
integers = (module.py.TestInt(val=val) for val in range(10))
factory = DelimitedMessageFactory(BytesIO(), *integers)
# Rewind and read the stream of 10 protobuf messages
factory.rewind()
for offset_val in factory.message_read(module.py.TestInt):
print(f"TestInt message of val set to {offset_val[1]}")
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file proto_topy-1.0.5.tar.gz
.
File metadata
- Download URL: proto_topy-1.0.5.tar.gz
- Upload date:
- Size: 9.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 24036cb813de44ae3a32ffd51a87844d71e26ec69a26454b29c39e7a5465263e |
|
MD5 | e6d283b8e77761e859ac146101a4ba44 |
|
BLAKE2b-256 | ec8532f9f9bfca2432b152debddb6840fa45a53256bf07a6914d637a7eff0013 |
File details
Details for the file proto_topy-1.0.5-py3-none-any.whl
.
File metadata
- Download URL: proto_topy-1.0.5-py3-none-any.whl
- Upload date:
- Size: 7.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c8486016f3d5beeff309e75bdda43b3846f156af1c676e128764018538a68c0d |
|
MD5 | 2ddb0ad87cd55fa4199334c791802abf |
|
BLAKE2b-256 | 9c0aa34bf581f4ee02cade18689c1df9f960966459ce3a7d3dbe9c7220b018c2 |