Google文档电子表格(app-script):在不重复的电子表格之间复制数据

时间:2012-05-23 19:47:28

标签: google-apps-script

我有一段代码,用于在Google文档中为电子表格(app-script)将记录从一个电子表格传输到另一个电子表格。

function myFunction() {
    // Get Spreadsheets
    var source = SpreadsheetApp.openById("spreadsheetKeySource");
    var target = SpreadsheetApp.openById("spreadsheetKeyTarget");

    // Set Sheets
    var source_sheet = source.getSheetByName("Sheet1");
    var target_sheet = target.getSheetByName("Sheet1");

    // Get target last row
    var last_row = target_sheet.getLastRow();

    // Set Ranges
    var source_range = source_sheet.getRange("A1:B1");
    var target_range = target_sheet.getRange("A"+(last_row+1)+":B"+(last_row+1));

    // Fetch values
    var values = source_range.getValues();

    // Save to spreadsheet
    target_range.setValues(values);
}

我需要知道是否可以从源中获取内容并循环遍历它,并且只添加目标中不存在的记录。 显然,这个功能不足以达到这个目的,我希望有人可以把我推向正确的方向,甚至提供一个代码片段作为例子。到目前为止,我在谷歌或这里找不到任何有用的东西...... :(

谢谢你的帮助

修改

我能够完成这项工作。范围已更改,现在我不得不从多个工作表中获取数据以获取多个工作表,仅提取电子邮件并将其添加到主电子邮件电子表格中。这是我创建的代码,希望它也可以帮助其他人。

我实际上在打开masterSpreadsheet时运行了这个脚本,并添加了一个菜单按钮来运行这个脚本。

/**
* Updates the master spreadsheet with the set source spreadsheets and pages
**/
function updateMasterSpreadsheet() {
  //  var sourceSpreadsheetsArray = new Array();
  var sourceSpreadsheetsObject = new Object;

  // Add Spreadsheet IDs and sheet names that need to be copied from
  sourceSpreadsheetsObject['sourceSpreadsheet1Key'] = new Array("Sheet1");
  sourceSpreadsheetsObject['sourceSpreadsheet2Key'] = new Array("Sheet1");

  // Open master spreadsheet
  var target = SpreadsheetApp.openById("masterSpreadsheetKey");

  // Open master sheet
  var target_sheet = target.getSheetByName("Sheet1");

  // Loop through all source spreadsheets
  for (var id in sourceSpreadsheetsObject) {
    // Open source spreadsheet
    var source = SpreadsheetApp.openById(id);

    // Loop through and process each sheet
    for (var sheetID in sourceSpreadsheetsObject[id]) {
      // Open source spreadsheet sheet
      var source_sheet = source.getSheetByName(sourceSpreadsheetsObject[id][sheetID]);

      // Process sheet
      _updateMasterSpreadsheet(source_sheet, target_sheet);
    } // END - source sheets loop 

  } // END - source spreadsheets loop

  // Add last updated
  target_sheet.getRange("B1").setValue(new Date());
}

/**
* Performs the actual copy into the master spreadsheet
**/
function _updateMasterSpreadsheet(source_sheet, target_sheet) {
  // Get target last row
  var last_row = target_sheet.getLastRow();  

  // Get Source Range
  var source_range = source_sheet.getDataRange();

  // Fetch Source Values
  var source_data = source_range.getValues();  

  //Iterate over all cells, looking for non-empty ("") cells
  for (var row in source_data) {

    // check if empty
    if (source_data[row][0]!= "") {
      // Fetch data in the sheet (do this in the loop to ensure that we check all newly added items)
      var target_range = target_sheet.getDataRange();
      var target_data = target_range.getValues();  

      // Set flags
      var found = false;
      var stop = false;

      // Process loop
      while(found == false && stop == false) {
        // Check for duplicates
        for (var tmpRow in target_data) {
          if (source_data[row][0] == target_data[tmpRow][0]) {
            found = true;
            break;
          }
        }

        // If no duplicate, add to sheet
        if (!found) {
          last_row++;
          target_sheet.getRange("A"+last_row).setValue(source_data[row][0]);
        }

        // Prevent infinite loop
        stop = true;
      }
    }
  }
}

2 个答案:

答案 0 :(得分:1)

Google Apps脚本文档中的本教程可以为您提供帮助:

Tutorial: Removing Duplicate Rows in a Spreadsheet

在Apps脚本库中还有一个名为“删除重复项”的脚本

答案 1 :(得分:0)

我们更有经验的人之一(这是很多)可能有不同的看法,但我猜你必须逐行比较两个。这只会假设未在任何一张表中手动更改内容。

你试图做什么?如果您描述您的用例,那么我们可能会提供其他想法......