Përmbajtje:
2025 Autor: John Day | [email protected]. E modifikuara e fundit: 2025-01-13 06:58
Në këtë Blogtut, ne do të dërgojmë leximet e sensorit SHT25 në fletët e Google duke përdorur Adafruit huzzah ESP8266 i cili ndihmon në dërgimin e të dhënave në internet.
- Dërgimi i të dhënave në qelizën e fletëve të Google është një mënyrë shumë e dobishme dhe themelore e cila i ruan të dhënat në formë tabelare në internet.
- Në vend që të përdorim çdo lloj ure të veçantë si shtyrja e një kutie ose MQTT NODE RED ose ndonjë lloj tjetër API REST, ne do t'i dërgojmë të dhënat duke përdorur skriptin google i cili merr lehtësisht të dhënat nga sensori duke përdorur lidhjen e skriptit të siguruar nga aplikacioni i shkrimit të Google pas publikimit
- Ne mund të përdorim skriptimin për të dërguar të dhënat nga fleta google, dokumentet apo edhe në google drive.
- Thjesht mos përfundoni këtu më tej, ju mund të lidhni fletët e Google me çdo aplikacion të bazuar në ueb, të cilit i ndani të dhënat me përdoruesit ashtu siç donin
- Asnjë tarifë shtesë nuk do të paguhet ndryshe nga serverët e tjerë në internet këtu dhe ju mund të ruani të dhënat deri në 10 GB Maximum në llogarinë e përdoruesit dhe mund t'i përdorni
- Një nga përpjekjet më të mira është që ju mund të mësoni për lidhjen e të dhënave me internetin me këtë lloj aplikimi në kohë reale me lehtësi.
- Ne do të përdorim lidhjen I2C e cila kryen protokollin master-slave për të ndarë të dhënat me fletët e Google në një mënyrë fleksibile.
- Platforma e protokollit I2C lidh pajisjen e sensorit dhe punon me rreth 256 sensorë në të njëjtën kohë duke përdorur vetëm 2 tërheqje me tela për të transferuar të dhënat e sensorit në harduer 8 bit.
Hapi 1: Pajisje kompjuterike
Pajisje Adafruit HUZZAH Kits
Bordi Huzzah me pendë Adafruit
Adafruit I2C i përshtatur dhe përshtatës USB
SHT25 Sensori i Temperaturës dhe Lagështisë
Kabllo I2C
Hapi 2: Si funksionon Stuff
Marrja e leximeve të të dhënave në kohë reale të sensorëve përmes ESP8266 dhe dërgimi i të dhënave në platforma të ndryshme Cloud është shumë e thjeshtë.
Ne do të përdorim bibliotekën Wire.h në Arduino IDE për krijimin e komunikimit me dy tela midis Adafruit Huzzah Board dhe modulit SHT25 sensor I2C dhe kabllit I2C.
Shënim: Për të shmangur strukturën komplekse të telave, unë do të përdor përshtatësin I2C për Adafruit Huzzah i krijuar për të lidhur sensorin I2C.
Që fillestari të krijojë Esp8266 yo duhet të kalojë përmes konfigurimit të ESP8266
Fillimisht filloni bibliotekat:
- Bibliotekë me tela
- ESP8266WiFi
- WiFiClientSecure
Hapi 3: Procesi i ekzekutimit të modulit I2C në Arduino IDE
Pas fillimit të bibliotekave, ne do të përcaktojmë procesin I2C që do të përdoret për të tërhequr leximet e sensorit në konvertimin e tyre dhe zhvendosjen e të dhënave 8 bit sipas kërkesave:
Filloni regjistrat në protokollin I2C me dy tela për modulin e sensorit I2C
#përcaktoni Addr 0x40
- Filloni transmetimin I2C dhe filloni regjistrat dhe kërkoni të dhëna prej 2 bajtësh nga ku do të lexojmë të dhënat e sensorit.
- Nëse të dhënat 2 bajt do të jenë të disponueshme, atëherë lexoni të dhënat e sensorit dhe duke përdorur formulat e përmendura më poshtë po konvertojmë vlerat e dëshiruara
lagështia notuese = (((të dhënat [0] * 256.0 + të dhënat [1]) * 125.0) / 65536.0) - 6;
noton cTemp = (((të dhënat [0] * 256.0 + të dhënat [1]) * 175.72) / 65536.0) - 46.85;
noton fTemp = (cTemp * 1.8) + 32;
Shtypni vlerat në ekranin e monitorit serik
Hapi 4: Lidhja ESP8266 me WiFi dhe Google Spreadsheet
Pas ekzekutimit të moduleve I2C ne do të mësojmë se si të marrim të dhënat dhe duke përdorur bibliotekat WiFi dhe id -në e hostit si dhe çelësat API për të dërguar të dhënat në fletët e Google.
- Përcaktoni kredencialet WiFi në nivel global në ESP8266, të cilat do të na ndihmojnë të lidhim tabelën me internetin
- Siç do të përdorim klientin HTTP dhe do të përcaktojmë protokollin HTTPS = 443 për të siguruar rrugën HTTP pasi skripti do të funksionojë vetëm në rrugën e sigurt.
- Filloni detajet e hostit në kod
const char* host = "script.google.com";
const int httpsPort = 443;
String SCRIPT_ID = "përmendni ID -në e skriptit siç përmendet në kapjet";
Shënim: ID e skriptit përmendet në "URL -në e aplikacioneve të uebit" ndërsa kodi Gscript do të publikohet, thjesht kopjoni dhe ngjisni id -në e përmendur më poshtë dhe inicializoni në komandat e mësipërme
- Gjithashtu duke përdorur volatile with variable, ne do të inicializojmë variablin globalisht i cili merr të dhënat nga moduli I2C dhe i dërgon ato në skriptin URL i cili më tej do t'i dërgojë të dhënat në destinacion.
- Duke përdorur Bibliotekën WiFi ESP8266 ne do të jemi në gjendje të lidhim bordin me internetin
-
Të dhënat e sensorit do të mbahen në një server lokal pas çdo 5 sekondash.
- Me ndihmën e skriptit të URL -së, të dhënat do të mbahen në lidhjen e publikuar të shkrimit të Google, faqe aktive pas çdo 15 sekondash.
Hapi 5: Automatizoni Google Sheet duke përdorur GScript Editor
Ndërsa të gjithë kemi një llogari google për t'u identifikuar në fletën google me llogarinë tuaj
- Përmendni vlerat që ju nevojiten për të marrë nga sensori i lidhur me ESP8266
- Shkoni te Tools> Script Editor
- Përdorni funksionin "Doget" për të marrë ngjarjet
- Në funksionin "Doget" për të inicializuar çelësin API të spreadsheet si dhe lidhni Fletën Aktive ku dëshironi të dërgoni vlerat e sensorit
- Me ndihmën e funksionit të automatizimit të përmendur në kod për të përfaqësuar lehtë të dhënat në rreshta dhe kolona.
- Më në fund, ruani të dhënat dhe klikoni në "Publikim" >> Klikoni "Vendosni si aplikacione në internet"
- Sigurohuni sa herë që do të ketë ndonjë ndryshim për të zgjedhur "versionin e projektit" >> "E re" >> shtypni "përditësim"
URL -ja aktuale e aplikacionit në internet do të shfaqet si më poshtë:
script.google.com/macros/s/11GScript ID”/exec:
përdoret më tej në kodin ESP8266 për marrjen e të dhënave nga sensorët
Ne do të përdorim kërkesën HTTPS Get për të lidhur të dhënat me id -në e hostit të përmendur në redaktuesin gscript ku kemi koduar të dhënat tona më tej për t'u lidhur me fletën e Google.
funksioni doGet (e) {Logger.log (JSON.stringify (e)); // shiko parametrat var rezultat = 'Ok'; // supozoni sukses nëse (e.parametri == 'i papërcaktuar') {rezultati = 'Pa parametra'; } else {var sheet_id = ''; // Spreadsheet ID var sheet = SpreadsheetApp.openById (sheet_id).getActiveSheet (); var newRow = sheet.getLastRow () + 1; var rowData = ; } Logger.log (JSON.stringify (rowData)); // Shkruani rresht të ri më poshtë var newRange = sheet.getRange (newRow, 1, 1, rowData.length); newRange.setValues ([rowData]); }
Hapi 6: Kufizimet:
- Ky projekt është i kufizuar vetëm për të ruajtur të dhënat e sensorit I2C në fletët e Google
- Ne po përdorim kërkesën HTTPS GET për të marrë vlerat përmes funksioneve I2C
- Ne duhet të ndryshojmë vlerën në formatin e vargut dhe pastaj t'i dërgojmë të dhënat në lidhjen URL të gscript.
Hapi 7: Kodi, Kreditet, Referenca
Kodi Github:
github.com/varul29/SHT25_GoogleSheets_Goog…
Referenca
Kodi I2C:
Udhëzues për Google Script:
Dyqani i integruar:
Blog mësimor: