Skip to main content

Python library for encode and decode data in protobin format

Project description

protobin

protobin es una biblioteca Python diseñada para facilitar la interacción con el formato de transferencia de datos Protobin en modo binario. Esta biblioteca proporciona una interfaz sencilla y eficiente para:

  • Serializar objetos Python en datos Protobin.
  • Deserializar datos Protobin en objetos Python.
  • Validar la integridad de los datos Protobin.

Instalación

Para instalar protobin, puedes utilizar pip:

pip install protobin

Cómo empezar

Primeros Pasos

Declare un protocolo de la siguiente forma:

from protobin import Protocol
protocol = Protocol(js={'medida': [
        {'key': 'id', 'bytes': 1, 'type': 'unsigned'},
        {'key': 'nombre', 'type': 'string'},
        {'key': 'valor', 'bytes': 2, 'type': 'signed'}
    ]})

luego cree la variable que desea transmitir como un diccionario de python, codiféquela, decodifíquela, y compruebe que la información se recuperó correctamente

data = {'id': 2, 'nombre': 'Voltaje', 'valor': -20}
binary = protocol.encode(data, 'medida')
print('binary', binary)
recv = protocol.decode(binary, 'medida')
print('recv', recv)

Archivo Json

El protocolo se declara en un archivo *.json o un objeto dict en python. Éste contiene un diccionario donde cada clave del diccionario es el identificador de un formato.

{
  "formato1": [{}, {}, {}],
  "formato2": [{}, {}]  
}

Cada formato se declara como una lista de campos, y cada campo es representado por un diccionario, que debe tener un key para identificar el dato que se almacenará en esa posición, también debe tener un type que define el tipo de dato que se guardará y opcionalmente bytes o length para definir la cantidad de espacio o datos que se guardarán.

Tipos de Datos

array : Sirve para declarar listas de objetos, requiere el campo *array que contiene un formato completo.

bits : Sirve para declarar una lista de valores booleanos como un arreglo de bits en la cantidad necesaria de bytes. Es opcional el campo length si se quiere fijar una cantidad de elementos y usar un byte menos en su codificación.

bool : Sirve para declarar un único valor booleano en un byte. No requiere campos adicionales, ocupa 1 byte.

char : Sirve para declarar un único valor booleano en un byte. No requiere campos adicionales, ocupa 1 byte.

date : Sirve para declarar un valor datetime.date. No requiere campos adicionales, ocupa 3 bytes.

datetime : Sirve para declarar un valor datetime.datetime con presicion de segundos. No requiere campos adicionales, ocupa 6 bytes.

flags : Sirve para declarar una lista de keys cuyos valores sean booleanos y representarlos en un arreglo de bits. No requiere campos adicionales.

float : Sirve para declarar un valor numérico con una precisión fija de decimales. Requiere el campo bytes y decimales, tamaño variable.

signed : Sirve para declarar un valor entero positivo. Requiere el campo bytes, tamaño variable.

string : Sirve para declarar un texto. Es opcional el campo bytes, tamaño variable.

time : Sirve para declarar un valor datetime.time con presicion de minutos. No requiere campos adicionales, ocupa 2 bytes.

timestamp : Sirve para declarar un valor datetime.datetime con presicion de microsegundos. No requiere campos adicionales, ocupa 8 bytes.

unsigned : Sirve para declarar un valor entero. Requiere el campo bytes, tamaño variable.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

protobin-0.0.13.tar.gz (10.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

protobin-0.0.13-py3-none-any.whl (8.1 kB view details)

Uploaded Python 3

File details

Details for the file protobin-0.0.13.tar.gz.

File metadata

  • Download URL: protobin-0.0.13.tar.gz
  • Upload date:
  • Size: 10.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.6

File hashes

Hashes for protobin-0.0.13.tar.gz
Algorithm Hash digest
SHA256 b7556cc904e03fa731f482f2943384b21beb9ea7419baa99af7c75b562c769c0
MD5 93a7469b942963d73a0a6fa4509d9b63
BLAKE2b-256 c2d87e88bc626efce5b1eb1cec36be54d092b7bcd0670c0d8f63556ce7afc5f1

See more details on using hashes here.

File details

Details for the file protobin-0.0.13-py3-none-any.whl.

File metadata

  • Download URL: protobin-0.0.13-py3-none-any.whl
  • Upload date:
  • Size: 8.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.6

File hashes

Hashes for protobin-0.0.13-py3-none-any.whl
Algorithm Hash digest
SHA256 1beb8e6e31d971832ebeca11ca7a5ab9b4379d8254d166f130a75fac64c3ff5c
MD5 8a3e47a97e35ed25565d5c47f54eae5a
BLAKE2b-256 c3bc6d6b36bb9ee0924d84d7880732158f8ca26748276a18d7be8da12dc639b7

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page