1

我已经阅读了这两个链接谷歌脚本:有条件地将行从一个电子表格复制到另一个电子表格https://stackoverflow.com/a/4809413/1526044并且在尝试后我无法做我需要的事情。

我有一张电子表格,一张纸上有一些数据,另一张纸上有列的关键信息,可以通过这种方式进行比较:

KEY Value1 Value2 Value3 
AAA   B      C      D
BBB   Y      Z      W

我需要一个函数来逐行检查我的 DATA 电子表格,以查找键表上列值的值。当找到任何值时,它会在 DATA 电子表格的第一列(在同一行)写下 KEY 值。

示例:DATA 电子表格

empty text text text B
empty text text text text
empty text   C  text text
empty text text text Y

因此,在脚本之后,DATA 将如下所示:

AAA text text text B
empty text text text text
AAA text   C  text text
BBB text text text Y

任何其他建议将不胜感激。

4

1 回答 1

1

我修改了一个我最近回答的类似脚本,它应该可以满足您的需求。我没有测试,但你可以试一试。有一些评论可以解释这个想法......它可能需要一些调试。

编辑:我玩弄了这个并对其进行了更多调试;-)所以它现在似乎可以根据需要工作 - 这是我的测试表的链接

function xxx(){ 
/* we have an array 'keysheet'
    and an array datasheet , you get these with something like*/
        var keysheet = SpreadsheetApp.getActiveSpreadsheet().getSheets()[0].getDataRange().getValues();
    // and
        var datasheet = SpreadsheetApp.getActiveSpreadsheet().getSheets()[1].getDataRange().getValues();// if other columns, change index values in the arrays : 0=A, 1=B ...
    // the iteration could be like this :
              for(i=0;i<datasheet.length;++i){ // don't miss any data
                for(j=0;j<keysheet.length;++j){ // iterate through keysheet to find the keys
                  for(k=1;k<keysheet[0].length;++k){ // iterate in keysheet row to check every column except first one
                      var key = keysheet[j][k]
                      Logger.log(k+' '+key+"  "+datasheet[i].toString().match(key))
                 if(datasheet[i].toString().match(key) == key){// check whole rows to find if key is in data
                  var x = datasheet[i].shift();
                   datasheet[i].unshift(keysheet[j][0]) // if match found, replace first element in datasheet with fisrt element in keysheet
                     break  // if found break k loop maybe you should also break j loop ?
                       }
                 }
                   } //loop keysheet
             } // loop datasheet

            /* now you have a modified datasheet array that can directly overwrite the old datasheet 
            using setValues() */
            var sh = SpreadsheetApp.getActiveSpreadsheet().getSheets()[1];// assuming the datasheet sheet is sheet nr2
            Logger.log(datasheet)
           sh.getRange(1,1,datasheet.length,datasheet[0].length).setValues(datasheet);
              }
        //
于 2012-07-15T20:37:44.680 回答