-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy paththingspeak2mySQL.py
72 lines (60 loc) · 1.92 KB
/
thingspeak2mySQL.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
65
66
67
68
69
70
71
72
#!/usr/local/bin/python3
import thingspeak
import json
import mysql.connector as mariadb
result={}
mariadb_connection = mariadb.connect(user='', password='', host='', database='')
cursor = mariadb_connection.cursor()
cursor.execute("SELECT * FROM HUM ORDER BY ID DESC LIMIT 1") #HUM = DB Name
records = cursor.fetchall()
records = list(records[0])
records = records[2]
ch = thingspeak.Channel() #ChanelID
data1 = ch.get_field(field=1) #weight
data2 = ch.get_field(field=2) #temp
data3 = ch.get_field(field=3) #humidity
parsed1 = json.loads(data1)
parsed2 = json.loads(data2)
parsed3 = json.loads(data3)
data1 = parsed1['feeds']
data2 = parsed2['feeds']
data3 = parsed3['feeds']
#Write new weight Data
for i in data1:
a = i['entry_id']
b = i['created_at']
if a <= records:
pass
else:
if i['field1'] is not None:
result[a] = float(i['field1'])
cursor.execute("INSERT INTO WEIGHT (TIMESTAMP, KG) VALUES (%s,%s)",(b, result[a])) #change WEIGHT according to your DB
mariadb_connection.commit()
else:
pass
#Write new temperature Data
for i in data2:
a = int(i['entry_id'])
b = i['created_at']
if a <= records:
pass
else:
if i['field2'] is not None:
result[a] = float(i['field2'])
cursor.execute("INSERT INTO TEMP (TIMESTAMP, TEMP) VALUES (%s,%s)",(b, result[a])) #change TEMP according to your DB
mariadb_connection.commit()
else:
pass
#Write new humidity Data
for i in data3:
a = int(i['entry_id'])
b = i['created_at']
if a <= records:
pass
else:
if i['field3'] is not None:
result[a] = float(i['field3'])
cursor.execute("INSERT INTO HUM (TIMESTAMP, HUM, ID) VALUES (%s,%s,%s)",(b, result[a], a)) #change HUM according to your DB
mariadb_connection.commit()
else:
pass