如何解决如何在 App Script 中放置公式计算另一个工作表
我的第一个 ASK,最后一个是 2020 年。 我是谷歌应用脚本的新手,需要一些帮助 我有 2 个电子表格
- 带有 SHEET1 列 (
id,name,address,ts,visit
) 的电子表格 ssGETDATA - 带有 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
部分。
参考文献
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。