Questo esempio è la prosecuzione di quanto già visto in [apps script] Inviare tramite Gmail un’email ad un elenco di contatti in Spreadsheet
Voglio apportare solo una piccola modifica al codice per inviare un allegato salvato su Google Drive a tutti i soggetti nella lista. Per i riferimenti di programmazione rimando alla pagina della guida ufficiale.
Per prelevare un file da Google Drive dobbiamo anzitutto ottenere il suo riferimento univoco. Per farlo ci sono diversi modi, nel mio esempio utilizzerò un file pdf come questo qua. Anzitutto lo carico su Drive e poi cliccandoci sopra col destro scelgo Anteprima.
Dal menu in alto a destra seleziono Apri in un’altra finestra.
A questo punto nella barra dell’indirizzo vedrò qualcosa come https://drive.google.com/file/d/1234567890abcdefghijklmnopqrstuvwxyz/view
Copio il codice alfanumerico che ho evidenziato in rosso, che è l’identificativo univoco per ciascun file. Una volta copiato vado a modificare il mio codice nel modo seguente.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 |
function InviaEmailAllaLista() { var foglio = SpreadsheetApp.getActiveSheet(); var indirizzi = foglio.getRange("A:A").getValues(); var oggetti = foglio.getRange("B:B").getValues(); var messaggi = foglio.getRange("C:C").getValues(); var riga = 1; while( true ) { if( indirizzi[riga] == "" ) { break; } var file = DriveApp.getFileById('1234567890abcdefghijklmnopqrstuvwxyz'); GmailApp.sendEmail(indirizzi[riga], oggetti[riga], messaggi[riga], { attachments: [file.getAs(MimeType.PDF)], name: 'File di prova' }); riga++; } Browser.msgBox("Tutte le email sono state inviate!"); } |
In particolare con la prima istruzione aggiunta prelevo il file da Drive, cosa che richiederà dei permessi aggiuntivi.
1 |
var file = DriveApp.getFileById('1234567890abcdefghijklmnopqrstuvwxyz'); |
Mentre con file.getAs(MimeType.PDF)
creo il blob del file in formato PDF.
Fatto questo il mio nuovo script invia un’email a ciascun membro della lista con allegato il suddetto file.