如果单元格包含X到不同的工作表,则复制行,然后删除行。

时间:2018-02-08 02:58:53

标签: google-apps-script google-sheets

我一整天都在寻找如何做到这一点并且接近但从未完成状态。

我要做的是在活动电子表格上,查看工作表“快乐”。如果Colum G中的单元格包含“已关闭”,我想将该行的范围A:K之间的单元格复制到工作表“Sad”。完成复制并移动数据后,我想删除复制数据的“Happy”表上的整行。

IF cell =关闭,而不是复制到工作表并删除,否则没有。

我将每5分钟运行一次这个脚本,我可以使用触发器。

非常感谢任何帮助。

这是我到目前为止所尝试的内容

function Copy() {
 var sss = SpreadsheetApp.getActive()
 var ss = sss.getSheetByName('Happy');
 var range = ss.getRange('A:k'); 
 var data = range.getValues();

 var tss = SpreadsheetApp.getActive(); 
 var ts = tss.getSheetByName('Sad:'); 

 var valuesToCopy = ss.getRange(2,2,100).getValues();
  ts.getRange(2,ts.getLastRows()+1,valuesToCopy.length,1).setValues(valuesToCopy);

1 个答案:

答案 0 :(得分:1)

  function copyrange() {
  var ss = SpreadsheetApp.getActiveSpreadsheet();
  var sheet = ss.getSheetByName('Happy'); //source sheet
  var testrange = sheet.getRange('G:G');
  var testvalue = (testrange.getValues());
  var csh = ss.getSheetByName('Sad'); //destination sheet
  var data = [];
  var j =[];

  //Condition check in G:G; If true copy the same row to data array
for (i=0; i<testvalue.length;i++) {
  if ( testvalue[i] == 'Closed') {
  data.push.apply(data,sheet.getRange(i+1,1,1,11).getValues());
  //Copy matched ROW numbers to j
  j.push(i);
 }
 }
//Copy data array to destination sheet

 csh.getRange(csh.getLastRow()+1,1,data.length,data[0].length).setValues(data);

//Delete matched rows in source sheet
  for (i=0;i<j.length;i++){
  var k = j[i]+1;
  sheet.deleteRow(k);

//Alter j to account for deleted rows
  if (!(i == j.length-1)) {
  j[i+1] = j[i+1]-i-1;
}
}
}