Protolizer is a simple library to serialize and deserialize protobuf messages (JSON/dict ↔ protobuf). It does not require gRPC—only the protobuf package.
pip install protolizerFor running the project's tests (which use generated gRPC stubs), install dev dependencies:
pip install -r requirements.txt -r requirements-dev.txtfrom protolizer import Serializer, fields
class AccountSerializer(Serializer):
username = fields.CharField()
balance = fields.IntField()
class Meta:
# schema must be your generated protobuf message class (e.g. from *_pb2 import Account)
# Your .proto might look like:
# message Account {
# string username = 1;
# int32 balance = 2;
# }
schema = Account
# Define an account in JSON and Protobuf format
protobuf_data = Account(username='John', balance=100)
json_data = {'username': 'John', 'balance': 100}
# Serialize the data to Protobuf format
protobuf_serializer = AccountSerializer(protobuf_data)
print(protobuf_serializer.protobuf)
# Serialize the data to JSON format
json_serializer = AccountSerializer(json_data)
print(json_serializer.data)
# Deserialize the data from Protobuf format to JSON format
protobuf_deserializer = AccountSerializer(protobuf_serializer.protobuf)
print(protobuf_deserializer.data)
# Deserialize the data from JSON format to Protobuf format
json_deserializer = AccountSerializer(json_serializer.data)
print(json_deserializer.protobuf)If you want to see more examples, please check the examples directory.
Note: Meta.schema must be the generated protobuf message class (from your *_pb2 module). gRPC (grpcio) is only needed if you use gRPC services; for JSON ↔ protobuf conversion, the protobuf package alone is enough.
- CharField
- IntField
- FloatField
- BooleanField
- DateTimeField
- TimestampField
- DictField
- ListField
- CustomField (for custom responses)
- Fork the repository
- Create a branch for your feature
- Make your changes
- Create a pull request
- Wait for the code review
- If everything is OK, your pull request will be merged
This project is licensed under the MIT License - see the LICENSE file for details
This project is authored by @uwsgi on Telegram.