数据验证脚本循环

Data validation Script loop

我有一个代码可以在单元格旁边的范围内创建数据验证。

示例:

var cellC4 = cell.getRange('F11');
var range = SpreadsheetApp.getActive().getRange('MAIN!AG11:AG11');
var rule = SpreadsheetApp.newDataValidation().requireValueInRange(range).build();
cellC4.setDataValidation(rule);

var cellC5 = cell.getRange('F12');
var range = SpreadsheetApp.getActive().getRange('MAIN!AG12:AG12');
var rule = SpreadsheetApp.newDataValidation().requireValueInRange(range).build();
cellC5.setDataValidation(rule);

var cellC6 = cell.getRange('F13');
var range = SpreadsheetApp.getActive().getRange('MAIN!AG13:AG13');
var rule = SpreadsheetApp.newDataValidation().requireValueInRange(range).build();
cellC6.setDataValidation(rule);

var cellC7 = cell.getRange('F14');
var range = SpreadsheetApp.getActive().getRange('MAIN!AG14:AG14');
var rule = SpreadsheetApp.newDataValidation().requireValueInRange(range).build();
cellC7.setDataValidation(rule);

谁能帮我正确做一下

我卡在这里了:

function onOpen(){

var ss0 = SpreadsheetApp.getActiveSpreadsheet().getSheetByName('MAIN');  
var EndRow = ss0.getLastRow();

for ( var c = 16;c <= 25; c) {
for ( var i = 11;i <= EndRow; i++ ) {


//►PO# VALIDATION►

var range1 = ss0.getRange(i, c);
var rule1 = SpreadsheetApp.newDataValidation().requireValueInRange(range1).build();
ss0.getRange(i, 5).setDataValidation(rule1);
}}}

调查结果:

  • 这部分的循环 for ( var c = 16;c <= 25; c) { 使用 c 而不是 c++ 的错误迭代。因此,这个循环 永远不会完成 运行.

建议:

==更新===

您可以尝试下面的示例脚本:

function onOpen(){
  var ss0 = SpreadsheetApp.getActiveSpreadsheet().getSheetByName('MAIN');  
  var EndRow = ss0.getLastRow();
  for(row=11; row<=EndRow; row++){
    var data = ss0.getRange("P"+row+":Y"+row).getDisplayValues();
    var rule = SpreadsheetApp.newDataValidation().requireValueInList(data[0]).build();
    ss0.getRange(row,5).setDataValidation(rule);
  }
}

样本:

Result on column 5 or column E after the onOpen() function finishes running