email - 在同一个活动工作表中发送活动工作表的 PDF 附件以及电子邮件单元格参考
问题描述
我正在尝试将活动工作表和仅活动工作表作为 pdf 附件发送到位于单元格 C1 或 (1,3) 中的电子邮件
当前脚本执行,但我没有收到电子邮件。
function sendSheetToPdf(){
}
var ss = SpreadsheetApp.getActiveSpreadsheet();
var ssId = SpreadsheetApp.getActiveSpreadsheet().getId();
var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet();
var sheetName = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet().getName();
var email = sheet.getRange(1,3).getValue();
// Base URL
var url = "mysheetsurl", ss.getId());
/* Specify PDF export parameters
From: https://code.google.com/p/google-apps-script-issues/issues/detail?id=3579
*/
var url_ext = 'exportFormat=pdf&format=pdf' // export as pdf / csv / xls / xlsx
+ '&size=A4' // paper size legal / letter / A4
+ '&portrait=true' // orientation, false for landscape
+ '&fitw=true&source=labnol' // fit to page width, false for actual size
+ '&sheetnames=false&printtitle=false' // hide optional headers and footers
+ '&pagenumbers=false&gridlines=false' // hide page numbers and gridlines
+ '&fzr=false' // do not repeat row headers (frozen rows) on each page
+ '&gid='; // the sheet's Id
var token = ScriptApp.getOAuthToken();
var response = UrlFetchApp.fetch(url + url_ext + sheet.getSheetId(), {
headers : {
'Authorization' : 'Bearer ' + token
}
}).getBlob().setName(sheet.getName() + ".pdf");
sheet_as_pdf_blob_document=response;
// Email Business
var recipient = email;
var subject="Test"
var body="TEST.";
var nameOfSender="Test";
// Here we send the email
function sendReport() {
var message = {
to: recipient,
subject: subject,
body: body,
name: nameOfSender,
attachments: [sheet_as_pdf_blob_document]
}
MailApp.sendEmail(message);
}
我已经编写了成功发送电子邮件的脚本,但从未指定工作表名称和电子邮件地址。这次我想创建一种基于活动工作表发送电子邮件的动态方式。提前致谢!
解决方案
当前代码中的问题:
- 您的功能结构不正确。在您的编辑器中运行此代码时,您的代码应该会显示失败的执行日志。
这是它的样子:
function sendSheetToPdf(){
}
// process the sheet data and get pdf blob
function sendReport() {
//send email
}
您的基本网址不正确。根据您的参考资料指定 PDF 导出参数,您的基本 url 应该是这样的:
var url = "https://docs.google.com/spreadsheets/d/" + doc.getId() + "/export?
示例工作代码:
function sendSheetToPdf(){
var ss = SpreadsheetApp.getActiveSpreadsheet();
var ssId = SpreadsheetApp.getActiveSpreadsheet().getId();
var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet();
var sheetName = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet().getName();
var email = sheet.getRange(1,3).getValue();
// Base URL
var url = "https://docs.google.com/spreadsheets/d/"+ ss.getId()+"/export?";
/* Specify PDF export parameters
From: https://code.google.com/p/google-apps-script-issues/issues/detail?id=3579
*/
var url_ext = 'exportFormat=pdf&format=pdf' // export as pdf / csv / xls / xlsx
+ '&size=A4' // paper size legal / letter / A4
+ '&portrait=true' // orientation, false for landscape
+ '&fitw=true&source=labnol' // fit to page width, false for actual size
+ '&sheetnames=false&printtitle=false' // hide optional headers and footers
+ '&pagenumbers=false&gridlines=false' // hide page numbers and gridlines
+ '&fzr=false' // do not repeat row headers (frozen rows) on each page
+ '&gid='; // the sheet's Id
var token = ScriptApp.getOAuthToken();
var response = UrlFetchApp.fetch(url + url_ext + sheet.getSheetId(), {
headers : {
'Authorization' : 'Bearer ' + token
}
}).getBlob().setName(sheet.getName() + ".pdf");
var sheet_as_pdf_blob_document=response;
// Email Business
var recipient = email;
var subject="Test"
var body="TEST.";
var nameOfSender="Test";
// Here we send the email
var message = {
to: recipient,
subject: subject,
body: body,
name: nameOfSender,
attachments: [sheet_as_pdf_blob_document]
}
MailApp.sendEmail(message);
}
- 我刚刚修复了您的
base url
,将sendReport()
内容移到里面sendSheetToPdf()
,因为发送电子邮件所需的变量是在里面声明的sendSheetToPdf()
。
输出:
推荐阅读
- sql - 使用 switch case 连接两个表以避免一对多连接
- r - 从条件创建一个新的“ID”列
- javascript - 类型错误:getState 不是函数
- asp.net-core - Cronos cron Service Working Cron Job Demo net core 5
- php - 如何使可视化代码识别扩展中可用的类,例如 mongodb?
- html - 使用引导程序时未正确应用自定义样式
- c# - C# 数据存储切割输入
- julia - 如何防止模块中的全局变量或数组?
- java - 如何在android app中实现滑动功能
- installation - Azure Functions 的分发