我有一段代码,用于在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;
}
}
}
}
答案 0 :(得分:1)
Google Apps脚本文档中的本教程可以为您提供帮助:
Tutorial: Removing Duplicate Rows in a Spreadsheet
在Apps脚本库中还有一个名为“删除重复项”的脚本
答案 1 :(得分:0)
我们更有经验的人之一(这是很多)可能有不同的看法,但我猜你必须逐行比较两个。这只会假设未在任何一张表中手动更改内容。
你试图做什么?如果您描述您的用例,那么我们可能会提供其他想法......