สารบัญ สามารถคลิกเพื่อเลื่อนไปดูหัวข้อที่ต้องการได้เลย
ด้าน google sheet
สร้างไฟล์ google sheet ที่ต้องการ
data:image/s3,"s3://crabby-images/bf7b9/bf7b9b557c9592896484449f0229e46b108c1a70" alt=""
ที่ลิ้งค์ด้านบน จะมี Sheet id ตามตัวอย่างด้านล่าง ให้ก็อปปี้เอาไว้
data:image/s3,"s3://crabby-images/af9e6/af9e69cd3ef8a9638fcff4c088f34ed2dbf67226" alt=""
เลือกที่ ส่วนขยาย>Apps Scritp
data:image/s3,"s3://crabby-images/e1758/e17587d08045280b56cc7f17c9106754c0face8e" alt=""
จะเจอหน้าสำหรับใส่ Script ให้ส่งสคริปด้านล่างนี้
data:image/s3,"s3://crabby-images/e7806/e7806306e3f3cfa248304012b95122cd50d4a37c" alt=""
ดัานล่างนี้จะเป็นสคริปสำหรับรับค่า temp และ humid
function doGet(e) {
Logger.log(JSON.stringify(e));
var result = 'Ok';
if (e.parameter == 'undefined') {
result = 'No Parameters';
}
else {
var sheet_id = 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'; // Spreadsheet ID
var sheet = SpreadsheetApp.openById(sheet_id).getActiveSheet();
var newRow = sheet.getLastRow() + 1;
var rowData = [];
var Curr_Date = new Date();
rowData[0] = Curr_Date; // Date in column A
var Curr_Time = Utilities.formatDate(Curr_Date, "Asia/Bangkok", 'HH:mm:ss');
rowData[1] = Curr_Time; // Time in column B
for (var param in e.parameter) {
Logger.log('In for loop, param=' + param);
var value = stripQuotes(e.parameter[param]);
Logger.log(param + ':' + e.parameter[param]);
switch (param) {
case 'temperature':
rowData[2] = value; // Temperature in column C
result = 'Temperature Written on column C';
break;
case 'humidity':
rowData[3] = value; // Humidity in column D
result += ' ,Humidity Written on column D';
break;
default:
result = "unsupported parameter";
}
}
Logger.log(JSON.stringify(rowData));
var newRange = sheet.getRange(newRow, 1, 1, rowData.length);
newRange.setValues([rowData]);
}
return ContentService.createTextOutput(result);
}
function stripQuotes(value) {
return value.replace(/^["']|['"]$/g, "");
}
ในส่วนของ sheet id ให้เอา id จากลิ้งค์ของไฟล์ google sheet ที่เคยก็อปปี้ไว้แล้ว มาใส่ตามตัวอย่างด้านล่าง
data:image/s3,"s3://crabby-images/ef779/ef779dd28c4cf9c0f9cf6280a5732ba65174b115" alt=""
data:image/s3,"s3://crabby-images/b935a/b935ad56a58826504057a603adb87a22de3fea7b" alt=""
data:image/s3,"s3://crabby-images/9e871/9e871cf7b7ef4066c4de16f9a4dbbcfdf8472ff8" alt=""
เลือกสร้างเป็นเว็บแอป
data:image/s3,"s3://crabby-images/e5e44/e5e4488dc7a96c257bd7d41a79e0578b076d82f5" alt=""
เลือกสิทธิการเข้าถึงเป็นทุกคน
data:image/s3,"s3://crabby-images/48949/4894911008c0076322e2a2740ca1bbb627a56cba" alt=""
data:image/s3,"s3://crabby-images/93216/932161226a03e5cb4aadd71fff53938180ef4508" alt=""
data:image/s3,"s3://crabby-images/90670/90670bab3c309212d96b62c1f801bc7df625bb58" alt=""
จะได้ URL ของ google sheet api ให้นำไปใส่ในโค้ด ESP8266
data:image/s3,"s3://crabby-images/7646b/7646bed94c30ff246764d1bbb1677c2cb2b401c9" alt=""
ทดสอบโดยการนำลิ้งค์ที่ได้มาต่อด้วยข้อความด้านล่าง (เป็น api สำหรับ http get)
?temperature=25&humidity=55
data:image/s3,"s3://crabby-images/a0828/a0828ad4a5fd3e2de699b22c700cdb1d44e00455" alt=""
จะเห็นว่า api นี้สามารถใช้งานได้กับ google sheet โดยใช้ http get
data:image/s3,"s3://crabby-images/3d43b/3d43bfe16430dc2f87c2ac5c4c3d22674ba8e89b" alt=""
ด้าน ESP8266
จะใช้ตัวอย่างของ http get ตามรูป
data:image/s3,"s3://crabby-images/ddb65/ddb65922cfd34a752c1087e086c466f1da160144" alt=""
และเพิ่มเติมสำหรับอ่านค่าจาก dht โดยส่งค่าขึ้น google sheet ทุก 10 วินาที
จะได้โค้ดตามด้านล่างนี้
No responses yet