从 API 调用 google 表单提交自定义函数更新单元格

Make custom function update cells from API call on google form submit

我创建了一个 google 表单,该表单 link 编辑为 google sheets table。提交后,表单中的数据会更新 linked sheet 中的 A-D 列。现在我想要一个自定义脚本在提交时调用外部 API 并将响应中的数据写入 E 列。我正在尝试调用天气 API 以便记录用户当时的天气数据提交了他的表格。

下面是我用来从 public METAR API 获取温度的函数,当我从打开的 google sheet 中的单元格调用它时,它工作正常文档。我无法从 google 文档中得到正确的是如何在提交表单时触发它以及如何将其 link 触发到 E 列和当前表单答案行。据我所知,不可能从单元格调用此函数,我需要以某种方式在脚本中引用单元格位置(触发脚本的行 + E 列)?

function GetMETAR() {
  var url = 'https://avwx.rest/api/metar/KJFK?options=&format=json&onfail=cache';
  var response = UrlFetchApp.fetch(url, {'muteHttpExceptions': true});
  var json = response.getContentText();
  var data = JSON.parse(json);
  var tempr = data.temperature.value;
  return tempr;
}

试试这个:

function GetMETAR(name,cell) {
  var name=name || 'Sheet2';//if you don't want to use the parameters you can set these defaults
  var cell=cell || 'B4';
  var ss=SpreadsheetApp.getActive();
  var sh=ss.getSheetByName(name);
  var rg=sh.getRange(cell);
  var url = 'https://avwx.rest/api/metar/KJFK?options=&format=json&onfail=cache';
  var response = UrlFetchApp.fetch(url, {'muteHttpExceptions': true});
  var json = response.getContentText();
  var data = JSON.parse(json);
  var tempr = data.temperature.value;
  rg.setValue(tempr);//cell that you want the data to go to.
}

谢谢@Cooper,这是我的最终代码:

function GetMETAR() {
  var ss=SpreadsheetApp.getActiveSheet();//set active sheet where form answers are stored 
  var lr = ss.getLastRow();//since form pastes last answer to last row we get its number
  var rg = ss.getRange(lr,8,1,5);//here I set range where I will paste info from API CALL
  var url = 'https://avwx.rest/api/metar/UUWW?options=&format=json&onfail=cache';//API url
  var response = UrlFetchApp.fetch(url, {'muteHttpExceptions': true});//API call
  var json = response.getContentText();//response JSON to text
  var data = JSON.parse(json);//JSON text parse
  var tempr = data.temperature.value;//parsing values
  var wind_spd = data.wind_speed.value;
  var baro = data.altimeter.value;
  var dew = data.dewpoint.value;
  var wind_dir = data.wind_direction.value;
  var values = [[tempr,wind_spd,wind_dir,baro,dew]];//cobining values in array to paste
  rg.setValues(values);//pasting in range
}

脚本设置为在表单提交时触发