Как отправить мой целевой лист в формате PDF на адрес электронной почты - PullRequest
0 голосов
/ 08 июня 2019

У меня есть форма, которая при отправке вызовет функцию для записи значений этого представления на соответствующий лист в электронной таблице. Затем я хочу отправить этот скорректированный лист кому-нибудь по электронной почте.

Я искал google api для получения помощи и не смог найти или восстановить правильный код

function sendpdf(){                 // Function trigger is on form submit

var ss = SpreadsheetApp.getActiveSheet();
var sourceSheet = ss.getSheetName();   
var workingRow = ss.getLastRow(); 
var dataRange = ss.getRange(workingRow, 1, 1, 4);
var data = dataRange.getValues();
var row = data[0]; // entire row
var col1 = row[0];  // first column timestamp A
var col2 = row[1];  // Client B
var col3 = row[2];  // Item  C

var sass = SpreadsheetApp.getActiveSpreadsheet();
var targetSheet = sass.getSheetByName(col2); 

targetSheet.insertRowBefore(4);
targetSheet.getRange("A4").setValue(col1);
targetSheet.getRange("B4").setValue(col2);
targetSheet.getRange("C4").setValue(col3);

MailApp.sendEmail(to:"reciever@email.com",subject:"See Attached PDF regarding" + col2,body:col2+" submitted a new request"


// , attach:targetSheet.pdf
// need the code to turn the targetSheet into a PDF and then email the PDF

)



}

Электронная таблица содержит 12 листов, и я ожидаю, что скрипт отправит по электронной почте соответствующий лист, который был только что настроен для кого-либо, и любая помощь будет принята

1 Ответ

0 голосов
/ 08 июня 2019
var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet();
var folderID = "FOLDERID"; // Folder id to save pdf in a folder.
var folder = DriveApp.getFolderById(folderID); 
var newSpreadsheet = SpreadsheetApp.create(pdfName); // Name new Spreadsheet
var sheet = sourcesheet.copyTo(newSpreadsheet); //copy activesheet to new spreadsheet
newSpreadsheet.getSheetByName('Sheet1').activate(); //select "sheet1"
newSpreadsheet.deleteActiveSheet(); //delete "sheet1"
var newFile = folder.createFile(newSpreadsheet);
var pdf = DriveApp.getFileById(newSpreadsheet.getId());
var theBlob = pdf.getBlob().getAs('application/pdf').setName(pdfName); //create pdf 
from new sheet in folder

var   url,  //create variable from url of the new sheet
    sheets = newSpreadsheet.getSheets()


url = Drive.Files.get(newSpreadsheet.getId())
      .exportLinks['application/pdf']; //create the pdf 
url = url + '&size=a4' + //paper size
'&portrait=true' + //orientation, false for landscape
'&fitw=true' + //fit to width, false for actual size
'&sheetnames=false&printtitle=false&pagenumbers=false' + //hide optional
'&gridlines=false' + //false = hide gridlines, true = show
'&fzr=false'; //do not repeat row headers (frozen rows) on each page, true = show
 var token = ScriptApp.getOAuthToken();
 var response = UrlFetchApp.fetch(url, {
  headers: {
     'Authorization': 'Bearer ' + token
 }
 });


DriveApp.getFilesByName(pdfName).next().setTrashed(true); //delete newSpreadsheet

var attachmentName = pdfName + '.pdf';

var optAdvancedArgs = {name: "NAMEFROM", htmlBody: htmlBody, replyTo : from, 
from:from, attachments: [response.getBlob().setName(attachmentName)], };  //attach pdf

GmailApp.sendEmail(mailTo, subject, body, optAdvancedArgs); //send email with 
advanced arguments

Это должно помочь тебе ... Удачи !

...