使用Google Apps脚本进行数据复制

时间:2013-01-31 21:11:18

标签: javascript google-apps-script

我正在尝试在Google Apps脚本中编写一个脚本,该脚本从一张纸上获取单元格信息并将其复制到另一张纸上,这两种方法都只是为了抓住某些列以显示在第二张纸上而且还根据单元格内的值显示条件在某一栏中。以下是我到目前为止的情况:

function onMyEdit() {
  var myMaster    = SpreadsheetApp.openById("xxxxx");
  var masterSheet = myMaster.setActiveSheet(myMaster.getSheets()[0]);
  var myNames     = SpreadsheetApp.openById("xxxxx");
  var namesSheet  = myNames.setActiveSheet(myNames.getSheets()[0]);
  var row1        = masterSheet.getRange(1, 1, masterSheet.getLastRow(), 1);
  var rowV        = row1.getValues();
  var firstArray  = masterSheet.getDataRange().getValues();
  var dataList    = [];
  for (var i = 1; i < rowV.length; i++) {
    dataList.push(firstArray[i][0]);
    dataList.push(firstArray[i][1]);
    dataList.push(firstArray[i][2]);
    dataList.push(firstArray[i][3]);

  }
  for (var j = 0; j < rowV.length - 1; j++) {
    namesSheet.getRange(2, j + 1, 1, 1).setValue(dataList[j]);
  }
}

因此截至目前,它仅适用于从第二行开始的一行(以允许列标题)。我想当我想根据单元格数据有条件地获取行时,我会在'for'循环中对条件使用'if'语句,但我希望数据复制到两个工作表中的下一个可用行。我想我会使用类似的东西:    'getLastRow + 1' 或类似的东西。由于数据量及其用途,我需要此代码尽可能高效。我对编程很陌生,所以请详细解释,再次感谢。

1 个答案:

答案 0 :(得分:0)

我不确定我到底知道你想要做什么,但是 - 从我的理解 - 这段代码片段应该为你提供一个更好的开始......

(我在代码中添加了一些注释来解释)

function onMyEdit() {
  var myMaster    = SpreadsheetApp.openById("MasterSheet ID");
  var masterSheet = myMaster.getSheets()[0]; // get 1rst sheet
  var myNames     = SpreadsheetApp.openById("NamesSheet ID");
  var namesSheet  = myNames.getSheets()[0]; // get 1rst sheet
  var firstArray  = masterSheet.getDataRange().getValues();
  var dataList    = [];
  for ( r = 1; r < firstArray.length; r++) { // iterate the first col of masterSheet
      if(firstArray[r][0]=='some condition'){ // if value in the first column == 'some condition get the second column cell in the new array (here you could change what you want to get)
        dataList.push([firstArray[r][1]])
  }
  }
  Logger.log(dataList)
  if(dataList.length>0){
namesSheet.getRange(1,namesSheet.getLastColumn()+1,dataList.length,1).setValues(dataList);//copy data in a column after last col
}
}