Automate Gmail Attachments to Google Drive Using JavaScript in Apps Script

Shikhar ShuklaShikhar Shukla
2 min read

Managing email attachments manually is tedious, but with Google Apps Script, you can automate the process in just a few lines of JavaScript. In this article, I’ll walk you through how to create a script that saves attachments from specific Gmail senders directly to a Google Drive folder.


Why JavaScript is Essential for Automation: JavaScript is one of the most versatile programming languages. While it's well-known for web development, JavaScript powers automation in tools like Google Apps Script. Here's why it's important:

  1. Universal: Runs on almost every platform, from web browsers to backend services.

  2. Integration-Friendly: Simplifies working with APIs and external services.

  3. Fast Learning Curve: Ideal for beginners and experienced developers alike.

By leveraging JavaScript in Google Apps Script, we can seamlessly integrate Gmail and Google Drive, building custom workflows like this.


Step-by-Step Guide:

Writing the Script

  1. Open Google Apps Script.

  2. Create a new project.

  3. Paste the following code:

     function saveAttachments() {
         const senderEmail = "example@example.com"; // Replace with the email address
         const folderName = "Gmail Attachments"; // Replace with your desired folder name
         const processedLabelName = "Processed"; // Label for processed emails
    
         const folder = DriveApp.getFoldersByName(folderName).hasNext()
             ? DriveApp.getFoldersByName(folderName).next()
             : DriveApp.createFolder(folderName);
    
         const processedLabel = GmailApp.getUserLabelByName(processedLabelName) ||
             GmailApp.createLabel(processedLabelName);
    
         const threads = GmailApp.search(`from:${senderEmail} -label:${processedLabelName}`);
         const messages = GmailApp.getMessagesForThreads(threads);
    
         messages.forEach(messageArray => {
             messageArray.forEach(message => {
                 const attachments = message.getAttachments();
                 attachments.forEach(attachment => {
                     folder.createFile(attachment);
                 });
                 message.getThread().addLabel(processedLabel);
             });
         });
    
         Logger.log(`Processed emails saved to folder: ${folderName}`);
     }
    
  4. Replace example@example.com with the sender’s email and Gmail Attachments with your folder name.


Setting Up Automation

  1. Click the Triggers (clock icon) in the Apps Script editor.

  2. Add a new trigger:

  3. Save the trigger and test it.


Key Learnings and Use Cases: This project highlights the power of JavaScript beyond traditional development:

  • Automating repetitive tasks.

  • Integrating apps and services with minimal effort.

  • Simplifying workflows for enhanced productivity.


With Google Apps Script and JavaScript, the possibilities for automation are endless. Whether you’re a developer or a productivity enthusiast, learning JavaScript can transform how you approach tasks.

I hope this tutorial inspires you to explore JavaScript-powered automation! Have questions? Let me know in the comments.

0
Subscribe to my newsletter

Read articles from Shikhar Shukla directly inside your inbox. Subscribe to the newsletter, and don't miss out.

Written by

Shikhar Shukla
Shikhar Shukla