El día de hoy veremos cómo imprimir recibos, facturas o tickets en una impresora térmica usando Python a través de un plugin desarrollado por mí.
Con esto podrás imprimir tickets desde Python sin importar si usas la terminal, Flask, Tkinter, Django o cualquier otra cosa, pues mientras uses Python podrás imprimir en una impresora térmica.
Con el plugin presentado aquí podrás imprimir imágenes, códigos de barras, texto con acentos, cambiar fuentes, rotar texto y mucho más en la impresora térmica usando Python y comandos ESC POS.
En estos días he creado un nuevo diseñador web para impresoras térmicas. El diseñador te guiará en el proceso de instalar tu impresora, compartirla e instalar lo necesario para imprimir tus diseños. Pruébalo en:
https://parzibyte.me/apps/ticket-designer/#/first-steps
Una vez que tengas tus diseños vas a poder imprimirlos desde cualquier lenguaje de programación, incluyendo Python.
Lo primero que debes hacer es definir la lista de operaciones que se van a hacer en la impresora térmica. Estas operaciones serán convertidas a comandos ESC POS. La lista de operaciones es un simple arreglo de Python:
operaciones = [
{
"nombre": "Iniciar",
"argumentos": [],
},
{
"nombre": "EscribirTexto",
"argumentos": ["Hola\nImpresora desde Python\n"],
},
{
"nombre": "DescargarImagenDeInternetEImprimir",
"argumentos": ["https://github.com/parzibyte.png", 380, 0, True],
},
]
Cada elemento de la lista es un diccionario que tiene la propiedad nombre de tipo cadena, indicando el nombre de la operación, así como una propiedad llamada argumentos que es un arreglo de cualquier tipo que contiene los argumentos de dicha operación.
Por ejemplo, la función para imprimir texto se llama EscribirTexto
y solo toma un argumento de tipo string que es el texto que será impreso en la impresora térmica:
{ "nombre": "EscribirTexto", "argumentos": ["Hola\nImpresora desde Python\n"], }
Vas a encontrar la lista de operaciones disponibles en la documentación oficial, así como su nombre, descripción, argumentos y ejemplos. Te recuerdo que, al ser una simple lista de Python, puedes crearla como tú prefieras y agregarle elementos usando append o definiendo la lista desde un inicio.
Cuando hayas creado la lista de operaciones puedes enviarla a la API HTTP local que convierte JSON a ESC POS. Primero arma la carga útil que contiene la lista de operaciones y el nombre de la impresora:
nombre_impresora = "Termica"
serial = ""
carga_util = {
"operaciones": operaciones,
"nombreImpresora": nombre_impresora,
"serial": serial,
}
Finalmente hay que enviar ese diccionario codificado como JSON a la API en el endpoint /imprimir. Para hacer la petición HTTP podemos usar el paquete requests (pip install requests
):
respuesta_http = requests.post("http://localhost:8000/imprimir", json=carga_util)
respuesta = respuesta_http.json()
if respuesta["ok"]:
print("Impresión exitosa")
else:
print("Error: " + respuesta["message"])
La API va a devolver un diccionario con la propiedad ok
y message
. Si la impresión ESC POS fue correcta, ok
estará en True
. En caso contrario, el mensaje de error estará en message
.
El código completo queda como se ve a continuación:
import requests
"""
Esta lista de operaciones puede ser infinita.
Puedes definirla así, o invocar a append cuantas
veces sea necesario
Lista de operaciones disponibles: https://parzibyte.me/http-esc-pos-desktop-docs/es/
"""
operaciones = [
{
"nombre": "Iniciar",
"argumentos": [],
},
{
"nombre": "EscribirTexto",
"argumentos": ["Hola\nImpresora desde Python\n"],
},
{
"nombre": "DescargarImagenDeInternetEImprimir",
"argumentos": ["https://github.com/parzibyte.png", 380, 0, True],
},
]
nombre_impresora = "Termica"
serial = ""
carga_util = {
"operaciones": operaciones,
"nombreImpresora": nombre_impresora,
"serial": serial,
}
respuesta_http = requests.post("http://localhost:8000/imprimir", json=carga_util)
respuesta = respuesta_http.json()
if respuesta["ok"]:
print("Impresión exitosa")
else:
print("Error: " + respuesta["message"])
Te lo repito: la lista de operaciones puede ser infinita y creada como tú prefieras; ya sea usando un ciclo, leyendo un archivo de texto, solicitando datos al usuario, etcétera.
Para que el código funcione necesitas el servidor local de la API ESC POS ejecutándose y que tu impresora esté compartida. Por favor, sigue los pasos que aparecen en la página previamente enlazada, ya que ahí está la API unificada.
La documentación completa está en: https://parzibyte.me/http-esc-pos-desktop-docs/es/
Como puedes ver, estamos imprimiendo imágenes en una thermal printer usando Python, además de códigos QR, códigos de barra, texto con estilo y caracteres personalizados.
Lo que resta ahora es leer la documentación en la página del plugin para que conozcas todos los métodos y de todo lo que es capaz: https://parzibyte.me/http-esc-pos-desktop-docs/es/
Te dejo con más tutoriales de Python y más detalles sobre el plugin.
Hoy te voy a presentar un creador de credenciales que acabo de programar y que…
Ya te enseñé cómo convertir una aplicación web de Vue 3 en una PWA. Al…
En este artículo voy a documentar la arquitectura que yo utilizo al trabajar con WebAssembly…
En un artículo anterior te enseñé a crear un PWA. Al final, cualquier aplicación que…
Al usar Comlink para trabajar con los workers usando JavaScript me han aparecido algunos errores…
En este artículo te voy a enseñar cómo usar un "top level await" esperando a…
Esta web usa cookies.