Skip to main content

A simple USB to I2C adapter that works.

Project description

A Simple USB to I2C Adapter that works.

The I2C Adapter allows python programs to connect to I2C/QUIIC/STEMMA-QT devices using off the shelf low cost boards such the Raspberry Pico or SparkFun Pro Micro - RP2040. The I2C adapter appears on the computer as a serial port (no device installation required) and acts as a USB to I2C bridge, and this Python package provides an easy to use API to interact with it using high level commands.

For example, the schematic below shows the wiring for the oled_demo.py example which drive an I2C OLED display using an I2C Adapter and the luma.oled python package.



Highlights

  • Provides USB to I2C-master bridge.
  • Supports Windows/Mac/Linux.
  • Uses low cost low cost off-the-shelf boards as adapters.
  • Does not require driver installation (it appears on the computer as standard a serial port).
  • Comes with an easy to use Python API.
  • Easy to modify/extend and to adapt to new hardware.
  • Permissive open source license. Comercial use OK, sharing and attribution not required.

Python API Example

Package installation

pip install i2c-adapter --upgrade

In the example below, we use an I2C Adapter that appears as serial port "COM7" to access an I2C device at address 0x08. First we write a single byte 0x00 and then read 20 bytes. Upon completion, the 'data' variable contains a bytearray with 20 bytes.

from i2c_adapter import I2cAdapter

i2c = I2cAdapter(port="COM7")
i2c_addr = 0x08
assert i2c.write(i2c_addr, bytearray([0]))
data = i2c.read(i2c_addr,  20)
print(data)

In the example below we scan the I2C bus address range 0x00 to 0x7f and look for devices that response to an empty write.

from i2c_adapter import I2cAdapter

i2c = I2cAdapter(port="COM18")
print(f"Scanning I2C bus 0x00 to 0x7f:")
for adr in range(0, 127):
    if i2c.write(adr, bytearray([0]), silent=True):
      print(f"  - Device at 0x{adr:02x}")

Documentation

Full documentation is available at https://i2c-adapter.readthedocs.io/

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

i2c_adapter-0.2.21.tar.gz (7.9 kB view details)

Uploaded Source

Built Distribution

i2c_adapter-0.2.21-py3-none-any.whl (8.4 kB view details)

Uploaded Python 3

File details

Details for the file i2c_adapter-0.2.21.tar.gz.

File metadata

  • Download URL: i2c_adapter-0.2.21.tar.gz
  • Upload date:
  • Size: 7.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.1

File hashes

Hashes for i2c_adapter-0.2.21.tar.gz
Algorithm Hash digest
SHA256 226c26af93b3a56cdab8f4829bdb0667ebb44fa3fdffc99226c16017131bfc9c
MD5 8f27bfb24517436187c1a2bcc419d90e
BLAKE2b-256 1c8e207ba40f77d733b94a363a5f65c763ad3f50a258be05f2b962fa64932e90

See more details on using hashes here.

File details

Details for the file i2c_adapter-0.2.21-py3-none-any.whl.

File metadata

File hashes

Hashes for i2c_adapter-0.2.21-py3-none-any.whl
Algorithm Hash digest
SHA256 c41d3c3e28ab8631523d4347d109b7e830f8ad831064ad38741295cf0a24310b
MD5 386c3cfe8b349cbf7efff75cd194c340
BLAKE2b-256 40cef7adc08e48a2d98db9086d1902fc14a06b0a0ec484ca9bcaaf73acee3e08

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page