forked from Honey-Pi/rpi-scripts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
read_bh1750.py
64 lines (53 loc) · 2.37 KB
/
read_bh1750.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
# -*- coding: utf-8 -*-
#!/usr/bin/python3
# Based on an article at https://www.raspberry-pi-geek.de/
# Modified for HoneyPi
import smbus
import time
import logging
logger = logging.getLogger('HoneyPi.read_bh1750')
DEVICE = 0x23 # 0x5C
power_down = 0x00
power_on = 0x01
reset = 0x07
bus = smbus.SMBus(1)
def convertToNumber(data):
result=(data[1] + (256 * data[0])) / 1.2
return (result)
def measure_bh1750(ts_sensor):
try:
fields = {}
if 'i2c_addr' in ts_sensor and ts_sensor["i2c_addr"] is not None:
DEVICE = int(ts_sensor["i2c_addr"], 16) # convert string to hexadecimal integer
# 0x10 0b00010000 //CHM: Continuously H-Resolution Mode
# 0x11 0b00010001 //CHM_2: Continuously H-Resolution Mode2
# 0x13 0b00010011 //CLM: Continuously L-Resolution Mode
#***0x20 0b00100000 //OTH: One Time H-Resolution Mode ***
# 0x21 0b00100001 //OTH_2: One Time H-Resolution Mode2
# 0x23 0b00100011 //OTL: One Time L-Resolution Mode
# For the beginning, the one time high resolution mode (OTH) was chosen.
data = bus.read_i2c_block_data(DEVICE, 0x20) # Start initial measurement
time.sleep(0.200) # Measurement take ~120 ms / 200 ms was chosen as a safe value.
data = bus.read_i2c_block_data(DEVICE, 0x20) # Collecting the value
# The address must be accessed a 2nd time so that the values are up-to-date.
# ThingSpeak fields
# Create returned dict if ts_field is defined
if 'ts_field' in ts_sensor and isinstance(convertToNumber(data), (int, float)):
if 'offset' in ts_sensor and ts_sensor["offset"] is not None:
data = convertToNumber(data)-ts_sensor["offset"]
fields[ts_sensor["ts_field"]] = round(data, 1)
return fields
except Exception as e:
logger.error('Error while reading BH1750 Sensor. Is it connected?')
return None
if __name__ == '__main__':
try:
lightLevel=convertToNumber(bus.read_i2c_block_data(DEVICE, 0x20))
print (format(lightLevel,'.2f') + " lux")
time.sleep(0.200)
lightLevel=convertToNumber(bus.read_i2c_block_data(DEVICE, 0x20))
print (format(lightLevel,'.2f') + " lux")
except (KeyboardInterrupt, SystemExit):
pass
except Exception as e:
logger.exception("Unhandled Exception in BH1750 Measurement")