Google脚本:有条件地在同一电子表格中将行从一个工作表复制到另一个工作表

Joh*_*ohn 5 google-sheets google-apps-script google-spreadsheet-api

我阅读了Google Script:有条件地将行从一个电子表格复制到另一个电子表格,但无法让它对我有用.

我需要一个脚本,允许我在下面做引用的文字.请随时编辑我的电子表格以制作完整的工作脚本.我会公开电子表格供任何人复制脚本供自己使用.我对剧本写作一无所知,所以我需要拼写出来.对不起,我就是这样一个菜鸟,但这会帮助我学习.

https://docs.google.com/spreadsheet/ccc?key=0AoJdwy8V1ldHdFA5M1M1Wlp1NHZhcmxJOUZKVEU4X3c&usp=sharing

如果工作表"All_Mileage"上的B列表示"John",那么我希望将该行复制并粘贴到Sheet"John"中,从第3行开始.

如果工作表"All_Mileage"上的B列表示"Adam",那么我希望将该行复制并粘贴到Sheet"Adam"中,从第3行开始.

如果工作表"All_Mileage"上的B列表示"Mike",那么我希望将该行复制并粘贴到Sheet"Mike"中,从第3行开始.

我在这里看到了其他脚本,但我无法让它们工作.就像我说的那样,当它来代码时,我比树苗更绿.

万分感谢!

Ser*_*sas 11

C.Lang是对的,这不是一个可以制作现成脚本的地方......但是因为这个问题很常见而且经常被解决,所以我花了几分钟时间来编写和测试...所以它是:

var ss=SpreadsheetApp.getActiveSpreadsheet();// some global variables
var master = ss.getSheetByName('All_Mileage');
var colWidth = master.getMaxColumns();


    function copyRowsOnCondition() {
      var data = master.getDataRange().getValues();
      for(n=2;n<data.length;++n){
        if(data[n][1].length<16){ // if not pre-filled with your text
        Logger.log(data[n][1])
         var dest = ss.getSheetByName(data[n][1].toString().replace(/ /g,''));//remove any spaces that could be included in the name so the name = sheetName for sure
         var destRange = dest.getRange(dest.getLastRow()+1,1);// the place to write
         master.getRange(n+1,1,1,colWidth).copyTo(destRange);the copy itself value & format
         }
      }// loop
    }
Run Code Online (Sandbox Code Playgroud)

编辑:因为我使用MasterSheet中的名称值来查找目标表,我认为通过使用相同的规则创建目标表不存在的情况可能是有用的,即.name = sheetName...

另一个问题是,无法知道哪些行已被复制...所以我创建了一个处理所有这些行的版本,只复制手动选择的行(即使只在一列中)并更改背景颜色告诉这些行已被处理.我还添加了一个最小舒适的菜单;-)

(如何在寒冷的周日下午保持忙碌;-)

var ss=SpreadsheetApp.getActiveSpreadsheet();
var master = ss.getSheetByName('All_Mileage');
var colWidth = master.getLastColumn();// last used col in masterSheet
var sheets = ss.getSheets();// number of sheets

function onOpen() {
  var menuEntries = [ {name: "Copy selected Rows to sheets", functionName: "copyRowsOnConditionV2"},

                     ];
  ss.addMenu("Copy functions",menuEntries);// custom menu
}
function copyRowsOnConditionV2() {
  var sheetNames = [];// array of existing sheet names
  var sheets = ss.getSheets();// number of sheets
  for(s=0;s<sheets.length;++s){sheetNames.push(sheets[s].getName())};
  ss.getActiveSelection().setBackground('#ffffbb'); 
  var selectedfirstRow = ss.getActiveSelection().getRowIndex();
  var selectedHeigth = ss.getActiveSelection().getHeight()
  var selectedFullRange = master.getRange(selectedfirstRow,1,selectedHeigth,colWidth);
  var data = selectedFullRange.getValues();
  for(n=0;n<data.length;++n){
    if(data[n][1].length<16){
     if(sheetNames.toString().match(data[n][1].toString().replace(/ /g,''))!=data[n][1].toString().replace(/ /g,'')){// if no sheet exist with this name
     var newSheet = ss.insertSheet(data[n][1].toString().replace(/ /g,''),ss.getSheets().length);// then create it
     master.getRange(1,1,2,colWidth).copyTo(newSheet.getRange(1,1));// and copy the headers on 2 first rows, then continue as usual
     newSheet.getRange(1,1).setValue('Gas Mileage Log - '+data[n][1].toString().replace(/ /g,''));// set name in header
     SpreadsheetApp.flush();
     var sheets = ss.getSheets();// number of sheets
     var sheetNames = [];// update array of existing sheet names
     for(s=1;s<sheets.length;++s){sheetNames.push(sheets[s].getName())};
     Logger.log(sheetNames)
     };
     var dest = ss.getSheetByName(data[n][1].toString().replace(/ /g,''));//find the destination sheet
     Logger.log(data[n][1].toString().replace(/ /g,''))
     var destRange = dest.getRange(dest.getLastRow()+1,1);// define range
     master.getRange(selectedfirstRow+n,1,1,colWidth).copyTo(destRange);// and make copy below last row
     }
  }
}
Run Code Online (Sandbox Code Playgroud)

下图:

在此输入图像描述