gpt4 book ai didi

javascript - getRange、getDataRange 和 getActiveRange 之间的区别?

转载 作者:行者123 更新时间:2023-11-29 19:11:37 28 4
gpt4 key购买 nike

如果问题不是很明显,我对 Google Apps 脚本还很陌生。我正在尝试编写一个电子表格函数,该函数遍历工作簿中表单提交表的每一行,并根据第一个使用 for 循环的单元格的值更新第二个工作表/范围(在同一工作簿中)。但是,当我运行该函数时没有任何反应。

我很确定错误出在我定义相关范围的方式上,但我不是 100% 确定。这是我所写内容的修改版本:

function update() {
var ss = SpreadsheetApp.getActiveSpreadsheet();

var secondSheet = ss.getSheets()[1];
var submissionSheet = ss.getSheets()[0];

var secondRowEnd = secondSheet.getLastRow();
var submissionRowEnd = submissionSheet.getLastRow();

var secondColumnEnd = secondSheet.getLastColumn();
var submissionColumnEnd = submissionSheet.getLastColumn(); //used to define ranges dynamically

var secondRange = secondSheet.getValues();
var submissionRange = submissionSheet.getValues();

for(var i = 2; i <= submissionRowEnd; i++) {

var rock = secondRange.getCell(i, 1).getValue();
var paper = secondRange.getCell(i, 2).getValue();
var scissors = secondRange.getCell(i, 3).getValue();

var status = secondRange.getCell(i, 4).getValue();
var forStatus = secondRange.getCell(i, 5).getValue();

if (status === "Do X!") {
for(var j = 2; j <= submissionRowEnd; j++) {

var jrock = submissionRange.getCell(j, 1).getValue();
var jpaper = submissionRange.getCell(j, 2).getValue();
var jscissors = submissionRange.getCell(j, 3).getValue();
var jstatus = submissionRange.getCell(j, 4).getValue();

if (status === forStatus) {
jrock.setValue(rock);
jpaper.setValue(paper);
jscissors.setValue(scissors);
} else { /*do nothing*/ }
}
}
}

几个星期以来,我一直在关注这段代码的略有不同的版本,所以任何人和所有关注此代码的人都将不胜感激!

最佳答案

只需查看 Spreadsheet Service 的 Apps 脚本 API 引用.所有功能都记录在那里。以下是您需要的方法说明的链接:

getRange() 有多个实现。

关于javascript - getRange、getDataRange 和 getActiveRange 之间的区别?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38461098/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com