如何解决如何检查复选框是否被选中,并根据它更改另一个单元格中的数据,重复多行
我正在尝试制作一个脚本,每当触发时,它都会运行每一行,检查是否选中了 F 列中的复选框。如果是这样,该行中 A 列的内容将替换为 0。运行代码后,什么也没有发生。我不确定脚本在哪里,但我认为它在 for() 循环中。为了更容易理解,我还附上了电子表格本身的图片。任何帮助表示赞赏。
我的代码:
function onEditButAgain(event){
var sheet = SpreadsheetApp.getActiveSpreadsheet();
var editedCell = sheet.getActiveCell();
var columnToSortBy = 6;
if(editedCell.getColumn() == columnToSortBy)
{
for(var x = 2; x<=100; x++)
{
var checked = sheet.getRange(x,6);
if(checked.isChecked == true)
{
var date = sheet.getRange(x,1);
date.setValue("0");
}
}
}
}
电子表格本身的图像:
解决方法
说明:
您的目标是手动执行一个脚本,该脚本将在选中 F 列中同一行中的单元格时更改 A 列中的值。
-
代码中明显的问题是
isChecked
,它应该是isChecked()
。当你想执行一个函数时你使用括号,在这种情况下你想执行isChecked
。 -
在这种情况下,
onEdit
脚本将是多余的。如果您想使用名为onEdit
的onEditButAgain
触发器,您必须创建一个 installable 触发器。但是您不需要为此目的的可安装触发器。 -
尽管您可以将本答案中的以下代码包含在一个简单的
onEdit()
函数中,但不会使用事件对象,并且代码不会 100% 有效。但是如果你想手动运行它,你无论如何都不需要触发器。 -
当您使用循环时,使用
getRange
或isChecked
或setValue
之类的方法不是一个好习惯,因为这些方法的计算成本很高,并且您的脚本将非常慢。改为使用数组和getValues
/setValues
。
解决方案:
function myFunction(){
const ss = SpreadsheetApp.getActive();
const sh = ss.getSheetByName('Sheet1'); // change it to your sheet name
const valA = sh.getRange('A2:A'+sh.getLastRow()).getValues().flat();
const cb = sh.getRange('F2:F'+sh.getLastRow()).getValues().flat();
const new_valA = cb.map((c,i)=> [c ? "0" : valA[i]]);
sh.getRange(2,1,new_valA.length,new_valA[0].length).setValues(new_valA);
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。