loops - Google Scripts For 循环

标签 loops google-apps-script google-sheets closures

我正在尝试将电子表格中的一些数据插入到另一个电子表格中,问题是循环没有按预期运行,它只给了我目标电子表格中的一个条目。我试过使用 while 并且没有任何功能,但它没有用。

这是代码:

function move(){
  var homeBook = SpreadsheetApp.getActiveSpreadsheet();
  var sheet = homeBook.getSheets()[0];
  var limit = sheet.getLastRow(); //number of rows in the sheet

  var evento = sheet.getRange(2, 1, limit-1).getValues(); //event list
  var descript = sheet.getRange(2,2,limit-1).getValues(); //description list
  var tags = sheet.getRange(2,3,limit-1).getValues(); //tag list
  var sheetsIDHome = sheet.getRange(2,4,limit-1).getValues(); //ID list


  var targetBook = SpreadsheetApp.openById("1t3qMTu2opYffLmFfTuIbV6BrwsDe9iLHZJ_ZT89kHr8"); //target workbook
  var target = targetBook.getSheets()[0]; //Sheet1
  var targetLimit =target.getLastRow(); //Rows with content
  var sheetsIDTarget = target.getRange(targetLimit, 4); // ID list
  var targetRow = targetLimit+1; //row where content is going to be inserted

for(i = 2;i <= limit;i++){//loop for each value to be inserted in each row of the target sheet
(function(x){
          target.getRange(targetRow,1).setValue(x);
          target.getRange(targetRow,2).setValue(descript[2]);
          target.getRange(targetRow,3).setValue(tags[3]);
          target.getRange(targetRow,4).setValue(sheetsIDHome[4]);
          targetRow = targetRow++; 
      })(i);
  };

最佳答案

您正在尝试访问根据第 1-4 列的值创建的四个数组。

您的 for语句需要匹配它们的结构,从 0 的第一个数组实例开始.您可以使用任何数组进行迭代,我选择了第一个。

此外,我已经删除了该功能并替换了 x来自 evento 的实例.
++增加变量的值,不需要在那里赋值。

for (var i = 0; i < evento.length; i++) {
  target.getRange(targetRow,1).setValue(evento[i]);
  target.getRange(targetRow,2).setValue(descript[i]);
  target.getRange(targetRow,3).setValue(tags[i]);
  target.getRange(targetRow,4).setValue(sheetsIDHome[i]);
  targetRow++; 
}

关于loops - Google Scripts For 循环,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32028204/

相关文章:

algorithm - 如何搜索给定 x 的 10^n ≡ 1 mod(9x) 的最小 n

google-apps-script - 类型错误 : Cannot find function getCell in object Sheet

google-apps-script - 谷歌表脚本 - 选择多个 a1 表示法范围

javascript - sendemail的Google AppScript语法错误。无法识别我的问题

google-apps-script - 如何以编程方式(使用触发器)active()修复Google工作表中最后占用的行中的此错误?

javascript - 将 Parse 的 JavaScript 框架与 Google Apps 脚本结合使用

asp.net - 建筑下拉菜单选择形式 : code block not supported in this context

javascript - 在循环内映射数组

JavaScript/jQuery - 拦截循环

google-apps-script - 在 Google Script 中压缩 PDF 文件