|
| 1 | +var ss = SpreadsheetApp.openById('your spreadsheet ID here'); |
| 2 | +var historyWeatherSheet = SpreadsheetApp.getActive().getSheetByName('Taipei City'); |
| 3 | +var logSheet = ss.getSheetByName('Log'); |
| 4 | +var taipeiToday = ss.getSheetByName('Sheet2'); |
| 5 | +var nextRow = logSheet.getLastRow() + 1; |
| 6 | + |
| 7 | +var currentTimeDate10 = logSheet.getRange(3, 9).getDisplayValue(); |
| 8 | +var currentTimeDate20 = logSheet.getRange(3, 11).getDisplayValue(); |
| 9 | +var currentTimeDate30 = logSheet.getRange(3, 13).getDisplayValue(); |
| 10 | +var currentTimeDate40 = logSheet.getRange(3, 15).getDisplayValue(); |
| 11 | +var todayTime = logSheet.getRange(2, 3).getDisplayValue(); |
| 12 | + |
| 13 | +function doGet(e){ |
| 14 | + //---------------------------------------------------------------------------------- |
| 15 | + //write_google_sheet() function in esp32 sketch, is send data to this code block |
| 16 | + //---------------------------------------------------------------------------------- |
| 17 | + //get data from ESP32 |
| 18 | + if (e.parameter == 'undefined') { |
| 19 | + return ContentService.createTextOutput("Received data is undefined"); |
| 20 | + } |
| 21 | + //---------------------------------------------------------------------------------- |
| 22 | + ssid = e.parameters.ssid; |
| 23 | + time = e.parameters.time; |
| 24 | + date = e.parameters.date; |
| 25 | + temp = e.parameters.temp; |
| 26 | + humid = e.parameters.humid; |
| 27 | + co2 = e.parameters.co2; |
| 28 | + |
| 29 | + //---------------------------------------------------------------------------------- |
| 30 | + logSheet.getRange("A" + nextRow).setValue(ssid); |
| 31 | + logSheet.getRange("B" + nextRow).setValue(date); |
| 32 | + logSheet.getRange("C" + nextRow).setValue(time); |
| 33 | + logSheet.getRange("D" + nextRow).setValue(temp); |
| 34 | + logSheet.getRange("E" + nextRow).setValue(humid); |
| 35 | + logSheet.getRange("F" + nextRow).setValue(co2); |
| 36 | + //---------------------------------------------------------------------------------- |
| 37 | + |
| 38 | + |
| 39 | + copyTodayWeather(); |
| 40 | + |
| 41 | + findinWeatherHistory(); |
| 42 | + |
| 43 | + //returns response back to ESP32 |
| 44 | + return ContentService.createTextOutput("Status Updated in Google Sheet"); |
| 45 | +} |
| 46 | + |
| 47 | +// get all the ID values we have in the sheet we want to check them. flat will convert all the returning |
| 48 | +// 2D array of values in a 1D array with all the IDs |
| 49 | +var idRange = historyWeatherSheet.getDataRange().getValues(); |
| 50 | + |
| 51 | +function findinWeatherHistory() { |
| 52 | + |
| 53 | + // Get the new incoming data (ID and Ok/Nok) with each form submit by accessing |
| 54 | + // the trigger object e which is the submited and new form response row |
| 55 | + |
| 56 | + // Iterate for 10 years ago |
| 57 | + Logger.log("Looking for hystorical weather value..."); |
| 58 | + |
| 59 | + for(i=0;i<idRange.length;i++){ |
| 60 | + |
| 61 | + if(idRange[i][0] == currentTimeDate10){ |
| 62 | + Logger.log("Found a match 10ys!"); |
| 63 | + // set its value to the one submitted by the form |
| 64 | + tempValueTemp10 = historyWeatherSheet.getRange(i+1, 2).getValue(); |
| 65 | + logSheet.getRange(nextRow, 9).setValue(tempValueTemp10); |
| 66 | + |
| 67 | + tempValueHumid10 = historyWeatherSheet.getRange(i+1, 3).getValue(); |
| 68 | + logSheet.getRange(nextRow, 10).setValue(tempValueHumid10); |
| 69 | + } |
| 70 | + |
| 71 | + if(idRange[i][0] == currentTimeDate20){ |
| 72 | + Logger.log("Found a match 20ys!"); |
| 73 | + // set its value to the one submitted by the form |
| 74 | + tempValueTemp20 = historyWeatherSheet.getRange(i+1, 2).getValue(); |
| 75 | + logSheet.getRange(nextRow, 11).setValue(tempValueTemp20); |
| 76 | + |
| 77 | + tempValueHumid20 = historyWeatherSheet.getRange(i+1, 3).getValue(); |
| 78 | + logSheet.getRange(nextRow, 12).setValue(tempValueHumid20); |
| 79 | + } |
| 80 | + |
| 81 | + if(idRange[i][0] == currentTimeDate30){ |
| 82 | + Logger.log("Found a match 30ys!"); |
| 83 | + // set its value to the one submitted by the form |
| 84 | + tempValueTemp30 = historyWeatherSheet.getRange(i+1, 2).getValue(); |
| 85 | + logSheet.getRange(nextRow, 13).setValue(tempValueTemp30); |
| 86 | + |
| 87 | + tempValueHumid30 = historyWeatherSheet.getRange(i+1, 3).getValue(); |
| 88 | + logSheet.getRange(nextRow, 14).setValue(tempValueHumid30); |
| 89 | + } |
| 90 | + |
| 91 | + if(idRange[i][0] == currentTimeDate40){ |
| 92 | + Logger.log("Found a match 40ys!"); |
| 93 | + // set its value to the one submitted by the form |
| 94 | + tempValueTemp40 = historyWeatherSheet.getRange(i+1, 2).getValue(); |
| 95 | + logSheet.getRange(nextRow, 15).setValue(tempValueTemp40); |
| 96 | + |
| 97 | + tempValueHumid40 = historyWeatherSheet.getRange(i+1, 3).getValue(); |
| 98 | + logSheet.getRange(nextRow, 16).setValue(tempValueHumid40); |
| 99 | + } |
| 100 | + |
| 101 | + } |
| 102 | + |
| 103 | +} |
| 104 | + |
| 105 | +function copyTodayWeather() { |
| 106 | + |
| 107 | + Logger.log("Value to look for: " + todayTime) |
| 108 | + |
| 109 | + |
| 110 | + // get all the ID values we have in the sheet we want to check them. flat will convert all the returning |
| 111 | + // 2D array of values in a 1D array with all the IDs |
| 112 | + var idRange2 = taipeiToday.getDataRange().getDisplayValues(); |
| 113 | + |
| 114 | + Logger.log("Looking for today weather value..."); |
| 115 | + |
| 116 | + for(i=0;i<idRange2.length;i++){ |
| 117 | + |
| 118 | + if(idRange2[i][24] == todayTime){ |
| 119 | + Logger.log("Found a match!"); |
| 120 | + // set its value to the one submitted by the form |
| 121 | + tempValueTemp = taipeiToday.getRange(i+1, 5).getValue(); |
| 122 | + logSheet.getRange(nextRow, 7).setValue(tempValueTemp); |
| 123 | + |
| 124 | + tempValueHumid = taipeiToday.getRange(i+1, 12).getValue(); |
| 125 | + logSheet.getRange(nextRow, 8).setValue(tempValueHumid); |
| 126 | + } |
| 127 | + } |
| 128 | + |
| 129 | +} |
0 commit comments