如何在 App Script 中放置公式计算另一个工作表

问题描述

我的第一个 ASK,最后一个是 2020 年。 我是谷歌应用脚​​本的新手,需要一些帮助 我有 2 个电子表格

  1. 带有 SHEET1 列 (id,name,address,ts,visit) 的电子表格 ssGETDATA
  2. 带有 SHEET1 列 (id,ts) 的电子表格 ssveRIFY

我使用此代码从 Android 发送数据:

function doGet(e) {
 return message("Error: Please Try Again");
        }
  
function doPost(e) {
var id= e.parameters.id[0];
var name= e.parameters.name[0];
var address= e.parameters.address[0];
var visit= e.parameters.visit[0];
        
      var ts = Utilities.formatDate(new Date(),"GMT+8","dd/MM/yyyy HH:mm:ss");
      var ss = SpreadsheetApp.getActive();
      var sh = ss.getSheets()[0];
      sh.appendRow([id,visit]);
      
      return message("Data Saved");
    } else {
      return message("Error: Please Try Again");
    }}}

function message(msg) {
  return ContentService.createtextoutput(msg);
}

我想验证来自 ssGETDATA 的数据,但数据 (id) 出现了多次。 所以我的想法每次执行附加行时都会将公式放在列(访问)中,并使用 =count(id,ssveRIFYSheet1!id) 检查它是否已验证

它如何应用于谷歌应用脚​​本?

我希望当 ssveRIFY 发生变化时,ssGETDATA 列 (visit) 也会计数。

谢谢你的解释。新年快乐

解决方法

检查列是否有值的最简单方法可能是使用 getValues(),并在数组中搜索行:

const range = sheet.getRange('A2:A')
const hasBeenValidated = range.getValues()
  .flat()
  .some(value => value === id)

if (hasBeenValidated) {
 // [...]
}

请注意,我假设 id 在列 A 上并且它有一个标题。

flat() 是必要的,因为 getValues() 返回一个二维数组(行数组),而我们只需要一个值数组。

使用此代码段,您可以在进行任何更改之前检查 ssGETDATA 和/或 ssVERIFY 中的现有条目。它应该适用于任何列,但您可能需要根据它的类型(例如日期)更改 value === id 部分。

参考文献