This project is the API library of CH347 USB-SPI/I2C/UART bridge chip based on Python.
Standard USB-HID mode setting of CH347 chip supported only
This library provides full access of SPI/I2C/UART settings and communication with CH347 USB-SPI/I2C/UART bridge chip in Python language.
For demonstration and code reference please refer to the demo.py
file in source page.
pip install ch347api
Python >= 3.7
hidapi
The communication protocol with CH347 through USB-HID I wrote in this project based on the official demonstration APP. In other words that it was inferred from captured HID package when APP communicates.
THUS, THIS API MAY NOT FULLY CAPABLE OF EVERY FUNCTION IN OFFICIAL API FROM CH347DLL.DLL.
- Now with fully compatible UART (UART1 with pins TXD1/RXD1/RTS1/CTS1/DTR1) support under mode 3 (which is HID mode),
- Baudrate supports ranging from 1.2K to 9M
- Multithread receiver for UART (optional, default is on) to receive the data in parallel
- Added independent I2C interface class objects (I2CDevice) and SPI interface class objects (SPIDevice)
- Added new demo file
demo.py
to demonstrate the usage of classes added above (simplified code) - Added device lock to make thread safe
- Now with fully compatible I2C support, I2C clock speed level: 0 -> 20KHz, 1 -> 100KHz, 2 -> 400KHz, 3 -> 750KHz
- Added test.py for demonstration