首页 > 解决方案 > 从谷歌表单提交的 API 调用中制作自定义函数更新单元格

问题描述

我创建了一个链接到谷歌表格的谷歌表单。提交后,表单中的数据会更新链接工作表中的 AD 列。现在我想要一个自定义脚本在提交时调用外部 API 并将数据从响应写入 E 列。我正在尝试调用天气 API 以便在用户提交表单时记录天气数据。

下面是我用来从公共 METAR API 获取温度的函数,当我从打开的谷歌工作表文档中的单元格调用它时,它工作正常。我无法从谷歌文档中得到的是如何在表单提交时触发它并将其链接到 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;
}

标签: google-apps-scriptgoogle-sheetsgoogle-forms

解决方案


尝试这个:

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.
}

推荐阅读