谷歌表脚本编辑器导入多个表

时间:2019-12-09 11:48:16

标签: csv google-apps-script google-sheets

客观

我正在尝试使用Google脚本编辑器将Google驱动器上的csv文件导入到我的Google工作表中。有人可以向我澄清我对脚本的误解以及需要进行哪些调整才能将多个工作表请求粘贴到下面吗?抱歉,如果这很简单,这是我第一次使用脚本编辑器,对此我并不熟悉。

问题

目前,我的代码仅填充1张数据。而不是将第二部分作为我要填充的下一张工作表,而使用不同的csv工作表ID。

我尝试过的

  • 更改变量使其更具唯一性,以使工作表将我的变量视为不同,因为我认为每次都在擦拭。
  • 查看其他在线帮助论坛而没有发现任何运气 我能理解的相似之处。

当前代码

function onOpen(e) {

SpreadsheetApp.getUi()

.createMenu('RefreshData')

.addItem('Run getCSV', 'getCSV')

.addToUi()

}



function getCSV() {

//ENTER YOUR CSV FILE ID IN THE getFileByID in the ""

var file = DriveApp.getFileById("<file_id>");

var csvFile = file.getBlob().getDataAsString();

var csvData = Utilities.parseCsv(csvFile);

//CHANGE SHEET NAME TO WHATEVER YOUR SHEET IS CALLED

var sheet = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Sheet1");

sheet.clear();

sheet.getRange(1, 1, csvData.length, csvData[0].length).setValues(csvData);

}

function getCSV() {

    //ENTER YOUR CSV FILE ID IN THE getFileByID in the ""

    var file = DriveApp.getFileById("<file_id2>");

    var csvFile = file.getBlob().getDataAsString();

    var csvData = Utilities.parseCsv(csvFile);

    //CHANGE SHEET NAME TO WHATEVER YOUR SHEET IS CALLED

    var sheet = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Sheet2");

    sheet.clear();

    sheet.getRange(1, 1, csvData.length, csvData[0].length).setValues(csvData);

    }

2 个答案:

答案 0 :(得分:2)

您已两次定义getCSV(),这将导致问题。函数名称(如变量)应唯一。否则,它们将被重写。

以两个test()函数为例。每次运行testAll()时,输出始终为2。

function testAll() {
  test(); // 2.0
  test(); // 2.0
}

function test() {
  Logger.log(1);
}

function test() {
  Logger.log(2);
}

您可以做的是修改getCSV(),使其接受输入,然后创建一个新函数,将数据传递给它。然后在菜单中调用该新功能。

/**
 * Add a custom menu to the spreadsheet.
 */
function onOpen(e) {
  SpreadsheetApp.getUi()
  .createMenu("RefreshData")
  .addItem("Get CSVs", "importSheets")
  .addToUi();
}

/**
 * Imports all CSV files.
 */
function getCSVs() {
  // Define the CSV files and where you want them to be saved
  var csvs = [
    { fileId: "FILE_ID_1", sheetName: "Sheet1" },
    { fileId: "FILE_ID_2", sheetName: "Sheet2" }
  ];

  // Import the CSVs
  for (var i = 0; i < csvs.length; i++) {
    getCSV_(csvs[i].fileId, csvs[i].sheetName);
  }
}

/**
 * Get the CSV data from a specified file and import into the desired
 * sheet of the active spreadsheet.
 * @param {String} fileId - The file ID of the CSV file
 * @param {String} sheetName - The name of the destination sheet
 */
function getCSV_(fileId, sheetName) {
  //ENTER YOUR CSV FILE ID IN THE getFileByID
  var file = DriveApp.getFileById(fileId);
  var csvFile = file.getBlob().getDataAsString();
  var csvData = Utilities.parseCsv(csvFile);

  //CHANGE SHEET NAME TO WHATEVER YOUR SHEET IS CALLED
  var sheet = SpreadsheetApp.getActiveSpreadsheet().getSheetByName(sheetName);
  sheet.clear().getRange(1, 1, csvData.length, csvData[0].length).setValues(csvData);
}

答案 1 :(得分:0)

创建了一个附加函数getCSV2,该函数声明工作表名称和ID,然后将其填充并在getCSV函数中循环。

function onOpen(e) {

SpreadsheetApp.getUi()

.createMenu('RefreshData')

.addItem('Run getCSV', 'getCSV')

.addToUi()

}

function getCSV() {
  getCSV2("sheet1", "<file_id1>");
  getCSV2("sheet2", "<file_id2>");
}

function getCSV2(name, id) {

var file = DriveApp.getFileById(id);

var csvFile = file.getBlob().getDataAsString();

var csvData = Utilities.parseCsv(csvFile);

var sheet = SpreadsheetApp.getActiveSpreadsheet().getSheetByName(name);

sheet.clear();

sheet.getRange(1, 1, csvData.length, csvData[0].length).setValues(csvData);

}
相关问题