首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >通过脚本下载Google中打开的电子表格的PDF版本

通过脚本下载Google中打开的电子表格的PDF版本
EN

Stack Overflow用户
提问于 2014-05-02 14:23:12
回答 2查看 4.4K关注 0票数 1

我一直在阅读如何通过Google脚本将电子表格保存为PDF。我遇到的大多数建议都是引用的,如下所示:

代码语言:javascript
复制
theOutputFile.saveAndClose();
DocsList.createFile(theOutputFile.getAs('application/pdf')).rename(theOutputName+".pdf");

也就是说,它们引用saveAndClose()函数。我不想保存或关闭我的电子表格-但我确实想下载当前的表格作为一个PDF。

有什么建议吗?谢谢。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-05-03 21:28:08

要将当前工作表保存为PDF格式,可以隐藏所有其他工作表,保存当前页,然后再次显示所有工作表。pdf的创建可能会在隐藏页结束之前开始,然后在pdf文件中包含2张表单--当前和最后一张。在showOneSheet和createPdf之间添加一个睡眠或确认消息框可以消除这个问题。

这个答案是Marco的答案的一个变体:在Google脚本给活动电子表格发送电子邮件中,“发送一张单张之前,您可以隐藏所有其他内容”。

代码语言:javascript
复制
var sheet = SpreadsheetApp.getActiveSheet();
var sheetToSave = sheet.getName();

showOneSheet(sheetToSave);
Utilities.sleep(2000);
createPdf("TestFolder", "TestPDF");
showAllSheets();  

function showOneSheet(SheetToShow) {
  var sheets = SpreadsheetApp.getActiveSpreadsheet().getSheets();
  for(var i in sheets){
    if (sheets[i].getName()==SheetToShow){
      sheets[i].showSheet();
    }
    else {
      sheets[i].hideSheet();
    }
  }
}

function showAllSheets() {
  var sheets = SpreadsheetApp.getActiveSpreadsheet().getSheets();
  for(var i in sheets){
      sheets[i].showSheet();
  }
}

function createPdf(saveToFolder, fileName){

  var ssa = SpreadsheetApp.getActiveSpreadsheet();
  var pdf = ssa.getAs("application/pdf"); 
  try {
    var folder = DocsList.getFolder(saveToFolder);
  }
  //Create Folder if not exists
  catch(error){
    folder = DocsList.createFolder(saveToFolder);
  }
  var file = folder.createFile(pdf);
  file.rename(fileName);

  return file;
}
票数 2
EN

Stack Overflow用户

发布于 2014-05-12 20:35:05

我能够让它使用@hsgv的答覆,但是,这是我最后使用的基于在这上面的版本。

代码语言:javascript
复制
// global save to folder variable:
var folderName = "My/Special/Folder";

function createInvoiceInGoogleDrive(){

  var spreadsheet = SpreadsheetApp.getActiveSpreadsheet();
  var sheet = spreadsheet.getActiveSheet();

  // getting some values from the spreadhseet for the file name
  var invoiceNumber = sheet.getRange("E3").getValue();
  var vendor = sheet.getRange("A9").getValue();

  var fileName = invoiceNumber + ' - ' + vendor + " - Invoice.pdf";

  var pdfBlob = sheetToPDF(spreadsheet, sheet);  
  pdfBlob.setName(fileName);

  var folder = getOrCreateFolder(folderName);

  var matchingFileList = folder.find(fileName);

  if ( matchingFileList.length > 0 ) {
    Browser.msgBox("ERROR: New invoice not created. " + fileName + " already exists at " + folderName);
    return false;
  } else {
    var f = folder.createFile(pdfBlob);
    spreadsheet.toast('Created a new invoice on Google Drive!');
    return true;
  }

}

// thanks: https://gist.github.com/gregorynicholas/9008572
function sheetToPDF(spreadsheet, sheet) {

  var ssID = spreadsheet.getId();  
  var gid = sheet.getSheetId();

  // &gid=x at the end of above url if you only want a particular sheet
  var url2 = "http://spreadsheets.google.com/feeds/download/spreadsheets/Export?key=" + ssID + 
            "&gid=" + gid + 
            "&fmcmd=12&size=7&fzr=true&portrait=true&fitw=true&locale=en&gridlines=false&printtitle=false&sheetnames=false&pagenum=UNDEFINED&attachment=true";

  // AUTH TOKEN required to access the UrlFetchApp call below.  You can receive it 
  // from https://appscripts.appspot.com/getAuthToken
  var AUTH_TOKEN = "{GET YOUR OWN AUTH TOKEN}"; 
  var auth = "AuthSub token=\"" + AUTH_TOKEN + "\"";

  var res = UrlFetchApp.fetch(url2, {headers: {Authorization: auth}}).getBlob();  
  return res; 
}

/**
 * Get or create a folder based on its name/path
 */
function getOrCreateFolder(folderName) {

  try {
    var theFolder = DocsList.getFolder(folderName);
  } catch(error){
    var theFolder = DocsList.createFolder(folderName);
  }

  return theFolder; 
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23430442

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档