Cover image
Try Now
2021-06-22

MCP23017/08 GPIO expander chip Python module for raspberrypi

3 years

Works with Finder

3

Github Watches

8

Github Forks

6

Github Stars

MCP230XX-Python-Module

Python 2.x and 3.x module to use the MCP23017 or MCP23008 GPIO expander chip and the Raspberrypi. This module supports using the interrupt capabilities on the MCP230XX chips

This requires the smbus module for the i2c connection and the RPi.GPIO or compatible module to use the interrupt capabilities.

Included at the end of the module are some example uses of the module

Connection to the MCP230XX from the Pi are as follows

  • Pi SCL to MCP SCL
  • Pi SDA to MCP SDA
  • Pi 3.3V to MCP VDD
  • Pi Gnd to MCP Vss
  • Pi 3.3V to MCP RESET (Could be tied to a Pi GPIO if you want active control of the RESET)
  • Pi 3.3V to MCP A0
  • Pi Gnd to MCP A1
  • Pi Gnd to MCP A2
  • Pi GPIO # to MCP INTA
  • Pi GPIO # to MCP INTB

With the above A0-A2 connections the i2c address is 0x21

For the MCP23008 the MCP GPIOA 0-7 are IO 0-7 in this module For the MCP23017 the MCP GPIOA 0-7 are IO 0-7 and the MCP GPIOB 0-7 are IO 8-15 in this module

Current functions include:

  • interrupt_options(outputType = 'activehigh', bankControl = 'separate')
  • set_register_addressing(regScheme='8bit')
  • set_mode(pin, mode, pullUp='disable')
  • invert_input(pin, invert = False)
  • output(pin, value)
  • input(pin)
  • add_interrupt(pin, callbackFunctLow='empty', callbackFunctHigh='empty')
  • remove_interrupt(pin)
  • register_reset()

Example uses

to initialize the chip

MCP = MCP230XX('MCP23017', i2cAddress, '16bit')

to set up an input and output

MCP.set_mode(0, 'output') # set IO 0 to an output MCP.set_mode(1, 'input') # set IO 1 to an input MCP.set_mode(10, 'input', 'enable') # set IO 10 to an input with the pullup enabled

to set an output

MCP.output(0,1) # set IO 0 high MCP.output(0,0) # set IO 0 low

to read an input

MCP.input(1) # reads current value on IO 1, return 0 for low and 1 for high

to set interrupt options

MCP.interrupt_options(outputType = 'activehigh', bankControl = 'separate')

  • the interrupt pins can be set as either activehigh, activelow or opendrain
  • for the MCP23017 the interrupts for IO 0-7 and IO 8-15 can be trigger INTA and INTB respectively with bankControl = 'seperate' or and an intterupt on any of the IO (0-15) can be sent to both INTA and INTB with bankControl = 'both'

to add and remove an interrupt to an input

MCP.add_interrupt(10, callbackFunctLow=functA, callbackFunctHigh=functB) # add interrupt to IO 10 with call back functions functA and functB

  • separate callback functs can be set for when the pin goes high and low, the same function can be used for callbackFunctLow and callbackFunctHigh

On the Raspberry Pi side using the RPi.GPIO module as IO, the following needs to be included in your program IO.add_event_detect(intPin,IO.RISING,callback=MCP.callbackB)

callback = either MCP.callbackA or MCP.callbackB if using the bankControl = 'seperate' or callback = MCP.callbackBoth if using the bankControl = 'both'

MCP.remove_interrupt(10) # remove interrupt from IO 10

相关推荐

  • Joshua Armstrong
  • Confidential guide on numerology and astrology, based of GG33 Public information

  • https://suefel.com
  • Latest advice and best practices for custom GPT development.

  • Emmet Halm
  • Converts Figma frames into front-end code for various mobile frameworks.

  • Elijah Ng Shi Yi
  • Advanced software engineer GPT that excels through nailing the basics.

  • https://maiplestudio.com
  • Find Exhibitors, Speakers and more

  • Yusuf Emre Yeşilyurt
  • I find academic articles and books for research and literature reviews.

  • Carlos Ferrin
  • Encuentra películas y series en plataformas de streaming.

  • https://zenepic.net
  • Embark on a thrilling diplomatic quest across a galaxy on the brink of war. Navigate complex politics and alien cultures to forge peace and avert catastrophe in this immersive interstellar adventure.

  • 林乔安妮
  • A fashion stylist GPT offering outfit suggestions for various scenarios.

  • https://reddgr.com
  • Delivers concise Python code and interprets non-English comments

  • 田中 楓太
  • A virtual science instructor for engaging and informative lessons.

  • ShrimpingIt
  • Micropython I2C-based manipulation of the MCP series GPIO expander, derived from Adafruit_MCP230xx

  • apappascs
  • Discover the most comprehensive and up-to-date collection of MCP servers in the market. This repository serves as a centralized hub, offering an extensive catalog of open-source and proprietary MCP servers, complete with features, documentation links, and contributors.

  • GeyserMC
  • A library for communication with a Minecraft client/server.

  • awslabs
  • AWS MCP Servers — specialized MCP servers that bring AWS best practices directly to your development workflow

  • Mintplex-Labs
  • The all-in-one Desktop & Docker AI application with built-in RAG, AI agents, No-code agent builder, MCP compatibility, and more.

  • 1Panel-dev
  • 💬 MaxKB is an open-source AI assistant for enterprise. It seamlessly integrates RAG pipelines, supports robust workflows, and provides MCP tool-use capabilities.

  • open-webui
  • User-friendly AI Interface (Supports Ollama, OpenAI API, ...)

  • GLips
  • MCP server to provide Figma layout information to AI coding agents like Cursor

  • activepieces
  • AI Agents & MCPs & AI Workflow Automation • (280+ MCP servers for AI agents) • AI Automation / AI Agent with MCPs • AI Workflows & AI Agents • MCPs for AI Agents

    Reviews

    5 (1)
    Avatar
    user_qSmxPV4t
    2025-04-17

    As a dedicated user of the MCP230XX-Python-Module, I am extremely impressed with its functionality and ease of use. This Python module, created by owainm713, greatly simplifies integrating MCP230XX I/O expanders into my projects. The documentation is clear, and the GitHub repository is well-maintained, making it an invaluable resource for developers. Highly recommended!