Skip to main content

bme280pi: the BME280 Sensor Reader for Raspberry Pi

Project description

Build Status Test Coverage Codacy Badge Maintainability pypi

bme280pi: the BME280 Sensor Reader for Raspberry Pi

How to Install

Enable the I2C Interface

  1. sudo raspi-config
  2. Select "Interfacing Options"
  3. Highlight the "I2C" option, and activate "Select" (use tab)
  4. Answer the question if you'd like the ARM I2C interface to be enabled with "Yes"
  5. Select "Ok"
  6. Reboot

For a walk-through with screenshots see the references below.

Install Utilities

Install python-smbus and i2ctools: sudo apt-get update && sudo apt-get install -y python-smbus i2c-tools

Then, shut down your Raspberry Pi: sudo halt . Disconnect your Raspberry Pi power supply. You are now ready to connect the BME280 sensor.

Connect the BME280 sensor

ModuleSetup

Install This Module

Installing With pip (Recommended)

You can then install this module by running pip install bme280pi

Installing From Source

If you want the latest version, you can check out the sources and install the package yourself:

git clone https://github.com/MarcoAndreaBuchmann/bme280pi.git
cd bme280pi
python setup.py install

Using it in your script

You can initialize the sensor class as follows:

from bme280pi import Sensor

sensor = Sensor()

You can then use the sensor object to fetch data, sensor.get_data(), which will return a dictionary with temperature, humidity, and pressure readings.

You can also just get the temperature (sensor.get_temperature()), just the pressure (sensor.get_pressure()), or just the humidity (sensor.get_humidity()).

Note that all commands support user-specified units, e.g. sensor.get_temperature(unit='F'), or sensor.get_pressure(unit='mmHg').

You can e.g. query the sensor every 10 seconds, and add the results to a dictionary, and then turn that into a pandas DataFrame and plot that (requires matplotlib and pandas):

import time
import datetime

import pandas
import matplotlib.pyplot as plt

from bme280pi import Sensor

measurements = {}

for i in range(20):
    measurements[datetime.datetime.now()] = sensor.get_data()
    time.sleep(10)

measurements = pd.DataFrame(measurements).transpose()

plt.figure()
plt.subplot(2, 2, 1)
measurements['temperature'].plot()
plt.title("Temperature (C)")

plt.subplot(2, 2, 2)
measurements['pressure'].plot()
plt.title("Pressure (hPa)")

plt.subplot(2, 2, 3)
measurements['humidity'].plot()
plt.title("Relative Humidity (%)")

plt.savefig("Measurements.png")

Reporting Issues

Please feel free to report any issues you encounter at the issue tracker.

References

Bosch BME280 Data Sheet

Raspberry-Spy: Using BME280 sensor in python

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

bme280pi-1.1.0.tar.gz (19.3 kB view details)

Uploaded Source

File details

Details for the file bme280pi-1.1.0.tar.gz.

File metadata

  • Download URL: bme280pi-1.1.0.tar.gz
  • Upload date:
  • Size: 19.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.24.0 setuptools/46.4.0 requests-toolbelt/0.9.1 tqdm/4.46.1 CPython/3.7.3

File hashes

Hashes for bme280pi-1.1.0.tar.gz
Algorithm Hash digest
SHA256 8e5b02522d400a11a9ed1a77d4ac028b1e6fd3dae99d4bf935a8329964cedd56
MD5 b1e1727886a262ab74e80846548d1186
BLAKE2b-256 4db5693505a217568533ebcd8d08d759b168f08575835e611b69b39e2885f4dc

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