Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pyusb/pyusb
Easy USB access for Python
https://github.com/pyusb/pyusb
hardware python usb
Last synced: 5 days ago
JSON representation
Easy USB access for Python
- Host: GitHub
- URL: https://github.com/pyusb/pyusb
- Owner: pyusb
- License: bsd-3-clause
- Created: 2011-09-02T18:36:18.000Z (over 13 years ago)
- Default Branch: master
- Last Pushed: 2024-08-16T11:53:47.000Z (4 months ago)
- Last Synced: 2024-12-07T19:26:31.488Z (6 days ago)
- Topics: hardware, python, usb
- Language: Python
- Homepage:
- Size: 1.22 MB
- Stars: 2,155
- Watchers: 92
- Forks: 667
- Open Issues: 28
-
Metadata Files:
- Readme: README.rst
- License: LICENSE
Awesome Lists containing this project
README
==================================
PyUSB – Easy USB access for Python
==================================Introduction
------------PyUSB provides for easy access to the host machine's Universal Serial Bus (USB)
system for Python 3.Until 0.4 version, PyUSB used to be a thin wrapper over libusb. Starting with
the 1.0 version, things changed considerably: now PyUSB is an API rich, backend
neutral Python USB module easy to use.Documentation
-------------The best way to get started with PyUSB is to read the following documents:
* `Tutorial`_
* `FAQ`_For more detailed information, PyUSB's API documentation, as with most Python
modules, is based on Python doc strings and can be manipulated by tools such as
pydoc [1]_::$ python -m pydoc usb
The `libusb 1.0 documentation`_ is also a recommended read, especially when
using that backend (more on this below).Requirements and platform support
---------------------------------PyUSB is primarily developed and tested on Linux and Windows, but it should
also work fine on any platform running Python >= 3.8, ctypes and at least one
of the built-in backends.PyUSB supports `libusb 1.0`_, libusb 0.1 and OpenUSB. Of those, libusb 1.0 is
currently recommended for most use cases.*On Linux and BSD,* these will generally be available on the distribution's
official repositories.*On macOS,* libusb 1.0 can easily be installed through Homebrew::
$ brew install libusb
*On Windows,* `pyocd/libusb-package`_ is a convenient [2]_ [3]_ way to
provide the necessary libusb 1.0 DLL, as well as a suitable PyUSB backend and
a easy to use wrapper over PyUSB's ``find()`` API::# with pure PyUSB
for dev in usb.core.find(find_all=True):
print(dev)# with pyocd/libusb-package
for dev in libusb_package.find(find_all=True):
print(dev)Alternatively, the libusb 1.0 DLL can be manually copied from an official
release archive into the ``C:\Windows\System32`` system folder, or packaged
together with the complete application.Installing
----------PyUSB is generally installed through pip [1]_::
# the latest official release
python -m pip install pyusb# install a specific version (e.g. 1.2.1)
python -m pip install pyusb==1.2.1# the latest snapshop from the official git repository
python -m pip install pyusb git+https://github.com/pyusb/pyusb#egg=pyusbMost Linux distributions also package PyUSB in their official repositories.
Getting help
------------If you have a question about PyUSB:
* consult the `FAQ`_;
* post a question in the `Q&A section`_;
* write to the `PyUSB mailing list`_.To report a bug or propose a new feature, use our `issue tracker`_. But please
search the database before opening a new issue.Footnotes
---------.. [1] On systems that still default to Python 2, replace ``python`` with
``python3``... [2] Unlike PyUSB, pyocd/libusb-package uses the more restrictive Apache 2.0
license... [3] While pyocd/libusb-package supports platforms other than Windows,
there are advantages to sticking to a system-provided libusb, if it is
available and the platform has a robust package manager (e.g. Linux, BSD,
macOS with Homebrew)... _FAQ: https://github.com/pyusb/pyusb/blob/master/docs/faq.rst
.. _PyUSB mailing list: https://sourceforge.net/projects/pyusb/lists/pyusb-users
.. _Q&A section: https://github.com/pyusb/pyusb/discussions/categories/q-a
.. _Tutorial: https://github.com/pyusb/pyusb/blob/master/docs/tutorial.rst
.. _issue tracker: https://github.com/pyusb/pyusb/issues
.. _libusb 1.0 documentation: https://libusb.info/
.. _libusb 1.0: https://github.com/libusb/libusb
.. _pyocd/libusb-package: https://github.com/pyocd/libusb-package/