Google App Script ContentService下载AsFile无效

时间:2015-06-14 20:35:01

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

我有一个使用Google App Script HtmlService开发的网络应用程序,并使用html表单,使用SpreadsheetApp在Google云端硬盘中填充Excel工作表。另一部分正在调用ContentService将数据下载为excel文件。

function doGet(e) {
  // Read excel sheet
  //getAppFile();
  // Render the application from HTML template
  return HtmlService.createTemplateFromFile('index').evaluate()
    .setTitle('Go Smart')
    .setSandboxMode(HtmlService.SandboxMode.IFRAME);
}

function downloadDoubleQuateCsvFile() {
  var sheetId =  PropertiesService.getScriptProperties().getProperty('sheetId');
  var ss = SpreadsheetApp.openById(sheetId).getActiveSheet();
    //var ss = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet();
    var maxColumn = ss.getLastColumn();
    var maxRow = ss.getLastRow();
    var data = ss.getRange(1, 1, maxRow, maxColumn).getValues();
    if (data.length > 1) {
        var csv = "";
        for (var row = 0; row < data.length; row++)  {
            for (var col = 0; col < data[row].length; col++) {
                if (data[row][col].toString().indexOf(",") != - 1) {
                    data[row][col] = "\"" + data[row][col] + "\"";
                }
            }

            if (row < data.length - 1) {
                csv += data[row].join(",") + "\r\n";
            } else {
                csv += data[row];
            }
        }

        csvFile = csv;
    }

    return makeCSV(csvFile);
}

function makeCSV(csvString) {
    var csvFileName = 'test.csv';
    var output = ContentService.createTextOutput();
    output.setMimeType(ContentService.MimeType.CSV);
    output.setContent(csvString);
    output.downloadAsFile(csvFileName);
    return output;
}

此脚本只是在控制台中提供工作表标题详细信息对象,而不是下载任何文件。

<button class="btn btn-success btn-sm" onclick="google.script.run.downloadDoubleQuateCsvFile()">Export</button>

在第二个函数中添加return后,我收到这样的错误。

Error: The script completed but the returned value is not a supported return type.

注意:我在带有数据的驱动器中有excel文件

1 个答案:

答案 0 :(得分:12)

要使downloadAsFile()方法起作用,必须从发布的URL调用的doGet()或doPost()返回contentservice对象。

示例:

 function doGet(){
        var output = ContentService.createTextOutput();
        output.setMimeType(ContentService.MimeType.CSV);
        output.setContent(csvString);
        output.downloadAsFile(csvFileName);
        return output;
}

在您的代码中,您将通过google.script.run将ContentService对象返回到网页。它不会要求从浏览器下载。事实上,返回contentservice对象将导致错误,因为它不是返回google.script.run调用的有效对象。仅允许本机javascript对象。

如果您希望它能够正常工作,您需要向用户显示一个指向您在另一个选项卡中指向您的脚本的链接。或者您也可以使用&#39;下载&#39;指向您的脚本的锚标记的属性。

例如,这假设您将返回修复程序保存到downloadDoubleQuateCsvFile():

function doGet(e){
   var serveCSV = e.parameter.servecsv;
   if(serveCSV){return downloadDoubleQuateCsvFile()}
   return HtmlService.createTemplateFromFile('index').evaluate()
.setTitle('Go Smart')
.setSandboxMode(HtmlService.SandboxMode.IFRAME);

}

在您的网页中:

<a href="//script.google.com/WebAppURL/exec?servecsv=true" target="_blank">Click here to download</a>

请记住,并非所有浏览器都支持此功能。 (只考虑chrome,opera,firefox支持自动下载)。