Google Spreadsheets:自动引用动态文件列表中的单元格数据

时间:2013-11-11 22:17:33

标签: google-sheets spreadsheet

我有一个使用Google电子表格创建的发票清单。现在,我想检索这些发票中的数据,以创建另一个名为“全部”的电子表格,其中包含每张发票的行。

Name Phone Street

John  677  Main
Mary  897  Niceday

有没有办法自动执行此操作而不是逐个引用单元格?

还有一个:想象一下,我添加了一个新的发票文件,我希望在添加它之后,其中的名称,电话和街道,会自动添加到“所有”文件。有可能吗?

1 个答案:

答案 0 :(得分:1)

如果所有文件都位于单个驱动器文件夹中,则可以从每个电子表格文件中检索所有数据,并使用onOpen函数将其添加到主电子表格文件中。

function onOpen(){
   // This active sheet.
   var mainSpreadsheet = SpreadsheetApp.getActiveSheet();
   // To store all of the invoice data
   var invoiceData = [];
   // Get all files inside a drive folder
   var files = DocsList.getFolderById("DRIVE FOLDER ID").getFiles();
   // For each file in the folder
   for (var i in files) {
      // Open the current spreadsheet in the interation
      var thisSpreadsheet = SpreadsheetApp.openById(files[i].getId());
      // Get the contents as an array and add it to invoiceData
      invoiceData.push(thisSpreadsheet.getDataRange().getValues());
   }
   // Clear all content in active sheet
   mainSpreadsheet.getDataRange.clearContent();
   // Get the write range from the number of values inside invoiceData
   var writeRange = mainSpreadsheet.getRange(1,1,invoiceData.length, invoiceData[0].length)
   // Add the data to the spreadsheet. 
   writeRange.setValues(invoiceData);
}

这是一个未经测试的示例。它会根据您文件中的标题而有所不同,但它应该是您开始的。