Skip to main content

A simple interface to GPIO devices with Raspberry Pi.

Project description

A simple interface to GPIO devices with Raspberry Pi, developed and maintained by Ben Nuttall and Dave Jones.

About

Component interfaces are provided to allow a frictionless way to get started with physical computing:

from gpiozero import LED
from time import sleep

led = LED(17)

while True:
    led.on()
    sleep(1)
    led.off()
    sleep(1)

With very little code, you can quickly get going connecting your components together:

from gpiozero import LED, Button
from signal import pause

led = LED(17)
button = Button(3)

button.when_pressed = led.on
button.when_released = led.off

pause()

You can advance to using the declarative paradigm along with provided to describe the behaviour of devices and their interactions:

from gpiozero import OutputDevice, MotionSensor, LightSensor
from gpiozero.tools import booleanized, all_values
from signal import pause

garden = OutputDevice(17)
motion = MotionSensor(4)
light = LightSensor(5)

garden.source = all_values(booleanized(light, 0, 0.1), motion)

pause()

See the chapter on Source/Values for more information.

The library includes interfaces to many simple everyday components, as well as some more complex things like sensors, analogue-to-digital converters, full colour LEDs, robotics kits and more. See the Recipes chapter of the documentation for ideas on how to get started.

Pin factories

GPIO Zero builds on a number of underlying pin libraries, including RPi.GPIO and pigpio, each with their own benefits. You can select a particular pin library to be used, either for the whole script or per-device, according to your needs. See the section on changing the pin factory.

A “mock pin” interface is also provided for testing purposes. Read more about this in the section on mock pins.

Installation

GPIO Zero is installed by default in the Raspberry Pi OS desktop image, available from raspberrypi.org. To install on Raspberry Pi OS Lite or other operating systems, including for PCs using remote GPIO, see the Installing chapter.

Documentation

Comprehensive documentation is available at https://gpiozero.readthedocs.io/. Please refer to the Contributing and Development chapters in the documentation for information on contributing to the project.

Issues and questions

If you have a feature request or bug report, please open an issue on GitHub. If you have a question or need help, this may be better suited to our GitHub discussion board, the Raspberry Pi Stack Exchange or the Raspberry Pi Forums.

Python 2 support

Contributors

See the contributors page on GitHub for more info.

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

gpiozero-1.6.0.tar.gz (166.4 kB view details)

Uploaded Source

Built Distribution

gpiozero-1.6.0-py2.py3-none-any.whl (147.0 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file gpiozero-1.6.0.tar.gz.

File metadata

  • Download URL: gpiozero-1.6.0.tar.gz
  • Upload date:
  • Size: 166.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.4.2 requests/2.23.0 setuptools/49.3.1 requests-toolbelt/0.8.0 tqdm/4.48.2 CPython/3.8.6

File hashes

Hashes for gpiozero-1.6.0.tar.gz
Algorithm Hash digest
SHA256 8b6c11e0d351c395cc256aff19cae23e7f7759a6164254a791c82877e3fcc5ef
MD5 9ecb4edcf53f66625c89f9f8e6274914
BLAKE2b-256 862ae2be12ed71978dffb73f72eee4d3d0abd8bf320089c802b8508398636272

See more details on using hashes here.

File details

Details for the file gpiozero-1.6.0-py2.py3-none-any.whl.

File metadata

  • Download URL: gpiozero-1.6.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 147.0 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.4.2 requests/2.23.0 setuptools/49.3.1 requests-toolbelt/0.8.0 tqdm/4.48.2 CPython/3.8.6

File hashes

Hashes for gpiozero-1.6.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 05dc40f7bceeb9d37c2efe6c5ae1b886725ef9b056e3a5a90d07b7fc0fed3a86
MD5 af65926755ae5dc0aaca60d861e814b3
BLAKE2b-256 7aec0c89ac6b0d70ee5ba954616df8214d1c15f888e595a0bb89133ab8cc0ce7

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