Go to file
dependabot[bot] 8274833255
Bump sphinx-rtd-theme from 1.3.0 to 2.0.0 (#596)
Bumps [sphinx-rtd-theme](https://github.com/readthedocs/sphinx_rtd_theme) from 1.3.0 to 2.0.0.
- [Changelog](https://github.com/readthedocs/sphinx_rtd_theme/blob/master/docs/changelog.rst)
- [Commits](https://github.com/readthedocs/sphinx_rtd_theme/compare/1.3.0...2.0.0)

---
updated-dependencies:
- dependency-name: sphinx-rtd-theme
  dependency-type: direct:production
  update-type: version-update:semver-major
...

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2023-11-30 08:38:40 +01:00
.github switch to python 3.12 (#582) 2023-10-09 00:13:39 +02:00
.vscode isort imports on save (#564) 2023-09-06 23:42:01 +02:00
capabilities-data@9a760e6f93 update capabilities data 2023-11-17 00:48:31 +01:00
doc Bump sphinx-rtd-theme from 1.3.0 to 2.0.0 (#596) 2023-11-30 08:38:40 +01:00
examples Bump werkzeug from 2.3.4 to 3.0.1 in /examples/docker-flask (#588) 2023-10-26 18:55:56 +02:00
src/escpos filter for ValueError too in dpi logic 2023-11-17 00:48:31 +01:00
test Separate method open() and constructor, enhance consistency between connectors: Rework printer tests (#587) 2023-10-28 20:52:59 +02:00
.coveragerc Enable branch coverage. 2016-08-30 18:00:06 +02:00
.gitignore Clean up tests and migrate (#540) 2023-08-10 00:18:02 +02:00
.gitmodules Modified submodule to always pull from master branch (#283) 2018-05-13 18:42:07 +02:00
.mailmap Feature(escpos) Add buzzer function (#535) 2023-07-27 19:10:19 +02:00
.readthedocs.yml Maintenance: fix read the docs and some annotations (#557) 2023-09-03 09:57:56 +02:00
AUTHORS update authors 2023-11-17 00:48:31 +01:00
CHANGELOG.rst prepare next release development cycle (#594) 2023-11-17 01:12:31 +01:00
CONTRIBUTING.rst modernize and cleanup documentation (#542) 2023-08-10 01:38:47 +02:00
INSTALL split off dependencies for optional installation (#546) 2023-08-17 01:37:50 +02:00
LICENSE change license to MIT 2017-01-31 03:55:50 +01:00
MANIFEST.in add capabilities to manifest 2020-05-09 00:37:35 +02:00
README.rst Enable spell checking (#563) 2023-09-07 22:08:31 +02:00
codecov.yml Clean up tests and migrate (#540) 2023-08-10 00:18:02 +02:00
pyproject.toml get mypy configuration change from #547 (#567) 2023-09-17 23:24:16 +02:00
requirements.txt ADD requirements.txt and requirements to setup.py 2015-11-27 23:13:48 +01:00
setup.cfg switch to python 3.12 (#582) 2023-10-09 00:13:39 +02:00
setup.py Drop Py37, improve typing and docstrings (#544) 2023-08-15 01:03:36 +02:00
tox.ini Restore types-pywin32 (#591) 2023-10-31 13:55:48 +01:00

README.rst

#############################################################
python-escpos - Python library to manipulate ESC/POS Printers
#############################################################

Description
===========

.. image:: https://readthedocs.org/projects/python-escpos/badge/?version=latest
    :target: https://python-escpos.readthedocs.io/en/latest/?badge=latest
    :alt: Documentation Status

Python ESC/POS is a library which lets the user have access to all those printers handled
by ESC/POS commands, as defined by Epson, from a Python application.

The library tries to implement the functions provided by the ESC/POS-command-set and supports sending text, images,
barcodes and qr-codes to the printer.

Text can be aligned/justified and fonts can be changed by size, type and weight.

Also, this module handles some hardware functionalities like cutting paper, control characters, printer reset
and similar functions.

Since supported commands differ from printer to printer the software tries to automatically apply the right
settings for the printer that you set. These settings are handled by
`escpos-printer-db <https://github.com/receipt-print-hq/escpos-printer-db>`_ which is also used in
`escpos-php <https://github.com/mike42/escpos-php>`_.

Dependencies
------------

This library makes use of:

* `pyusb <https://github.com/walac/pyusb>`_ for USB-printers
* `Pillow <https://github.com/python-pillow/Pillow>`_ for image printing
* `qrcode <https://github.com/lincolnloop/python-qrcode>`_ for the generation of QR-codes
* `pyserial <https://github.com/pyserial/pyserial>`_ for serial printers
* `python-barcode <https://github.com/WhyNotHugo/python-barcode>`_ for the generation of barcodes

Documentation and Usage
-----------------------

The basic usage is:

.. code:: python

    from escpos.printer import Usb

    """ Seiko Epson Corp. Receipt Printer (EPSON TM-T88III) """
    p = Usb(0x04b8, 0x0202, 0, profile="TM-T88III")
    p.text("Hello World\n")
    p.image("logo.gif")
    p.barcode('4006381333931', 'EAN13', 64, 2, '', '')
    p.cut()


Another example based on the Network printer class:

.. code:: python

    from escpos.printer import Network

    kitchen = Network("192.168.1.100") #Printer IP Address
    kitchen.text("Hello World\n")
    kitchen.barcode('4006381333931', 'EAN13', 64, 2, '', '')
    kitchen.cut()

Another example based on the Serial printer class:

.. code:: python

    from escpos.printer import Serial

    """ 9600 Baud, 8N1, Flow Control Enabled """
    p = Serial(devfile='/dev/tty.usbserial',
               baudrate=9600,
               bytesize=8,
               parity='N',
               stopbits=1,
               timeout=1.00,
               dsrdtr=True)

    p.text("Hello World\n")
    p.qr("You can readme from your smartphone")
    p.cut()


The full project-documentation is available on
`Read the Docs <https://python-escpos.readthedocs.io>`_.

Contributing
------------

This project is open for any contribution! Please see
`CONTRIBUTING.rst <https://python-escpos.readthedocs.io/en/latest/dev/contributing.html>`_
for more information.


Disclaimer
----------

None of the vendors cited in this project agree or endorse any of the
patterns or implementations.
Its names are used only to maintain context.