Go to file
Romain Porte b0ea9aec41 barcodes: replace viivakoodi with python-barcode
python-barcode is yet another clone of the PyPI barcode library, but
which is still developped compared to viivakoodi.

Signed-off-by: Romain Porte <microjoe@microjoe.org>
2020-05-10 13:36:16 +02:00
.github checkout submodules on github 2020-05-09 01:25:28 +02:00
.vscode add tox task for vscode 2020-05-09 00:07:02 +02:00
capabilities-data@3b5b35cfd3 update capabilities 2020-05-09 00:40:05 +02:00
doc barcodes: replace viivakoodi with python-barcode 2020-05-10 13:36:16 +02:00
examples drop Python 2.7 support 2020-05-10 10:55:44 +02:00
src/escpos drop Python 2.7 support 2020-05-10 10:55:44 +02:00
test drop Python 2.7 support 2020-05-10 10:55:44 +02:00
.coveragerc
.gitignore ignore vscode settings 2020-05-09 00:07:35 +02:00
.gitmodules
.mailmap
.travis.yml drop pypy 2020-05-09 01:35:00 +02:00
AUTHORS Merge pull request #380 from mofosyne/development 2020-05-08 23:21:59 +02:00
CHANGELOG.rst update changelog 2020-05-09 00:58:54 +02:00
CONTRIBUTING.rst drop Python 2.7 support 2020-05-10 10:55:44 +02:00
INSTALL
LICENSE
MANIFEST.in add capabilities to manifest 2020-05-09 00:37:35 +02:00
README.rst barcodes: replace viivakoodi with python-barcode 2020-05-10 13:36:16 +02:00
codecov.yml disable codecov status 2020-05-10 12:35:36 +02:00
readthedocs.yml build docs with python 3 2020-05-08 23:51:06 +02:00
requirements.txt
setup.cfg barcodes: replace viivakoodi with python-barcode 2020-05-10 13:36:16 +02:00
setup.py drop Python 2.7 support 2020-05-10 10:55:44 +02:00
tox.ini barcodes: replace viivakoodi with python-barcode 2020-05-10 13:36:16 +02:00

README.rst

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

.. image:: https://travis-ci.org/python-escpos/python-escpos.svg?branch=master
    :target: https://travis-ci.org/python-escpos/python-escpos
    :alt: Continous Integration

.. image:: https://codecov.io/github/python-escpos/python-escpos/coverage.svg?branch=master
    :target: https://codecov.io/github/python-escpos/python-escpos?branch=master
    :alt: Code Coverage

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


Description
-----------

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-commandset 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('1324354657687', '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('1324354657687', '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 <http://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.