Accedi a oltre 700 lab e corsi

Google Apps Script: Access Google Sheets, Maps & Gmail in 4 Lines of Code

Lab 40 minuti universal_currency_alt 1 credito show_chart Introduttivi
info Questo lab potrebbe incorporare strumenti di AI a supporto del tuo apprendimento.
Accedi a oltre 700 lab e corsi

GSP235

Google Cloud self-paced labs logo

Overview

In this lab, you are introduced to one of the easiest ways to write code that accesses Google developer technologies, all by leveraging one of the mainstream web development languages, JavaScript. Using Google Apps Script, you write code to extract an address sitting in a cell in a Google Sheet, generate a Google Map based on that address, and send a link to the map to yourself or a friend using Gmail. The best part? It really takes only 4 lines of code!

Objectives

  • Learn a bit about Apps Script... enough to get you going
  • Create a new Google Sheets spreadsheet
  • Learn how to enter the script editor for any document
  • Edit Apps Script code, save, and run it
  • Use Gmail to see the fruits of your labor!

Suggested experience

The following experience would enhance your learning experience:

  • Basic JavaScript skills (helpful but not required)
  • Basic spreadsheet skills

Setup and requirements

Before you click the Start Lab button

Read these instructions. Labs are timed and you cannot pause them. The timer, which starts when you click Start Lab, shows how long Google Cloud resources are made available to you.

This hands-on lab lets you do the lab activities in a real cloud environment, not in a simulation or demo environment. It does so by giving you new, temporary credentials you use to sign in and access Google Cloud for the duration of the lab.

To complete this lab, you need:

  • Access to a standard internet browser (Chrome browser recommended).
Note: Use an Incognito (recommended) or private browser window to run this lab. This prevents conflicts between your personal account and the student account, which may cause extra charges incurred to your personal account.
  • Time to complete the lab—remember, once you start, you cannot pause a lab.
Note: Use only the student account for this lab. If you use a different Google Cloud account, you may incur charges to that account.

Start your lab

  1. When you are ready, click Start Lab.

    The Lab Details pane appears with the temporary credentials that you must use to sign into Gmail for this lab.

    If you need to pay for the lab, a pop-up opens for you to select your payment method.

  2. Click Open Google Sheets.

    The lab spins up resources, and then opens another tab that shows the Sign in page.

    Tip: Open the tabs in separate windows, side-by-side.

  3. If necessary, copy the Username below and paste it into the Sign in dialog:

    {{{user_0.username | "Username"}}}
  4. Click Next.

  5. Copy the Password below and paste it into the Welcome dialog:

    {{{user_0.password | "Password"}}}
  6. Click Next.

  7. Accept all terms and conditions as prompted.

Google Sheets opens and you are signed in to your Student Google Account.

What is Google Apps Script?

Google Apps Script has a development environment that may be different from what you're used to. With Apps Script, you:

  • Develop in a browser-based code editor but can choose to develop locally if using clasp, the command-line deployment tool for Apps Script
  • Code in a specialized version of JavaScript customized to access Workspace, and other Google or external services (URLfetch, JDBC, etc.)
  • Safely ignore writing authorization code because Apps Script handles it for you
  • Do not host your app—it lives and runs on Google servers in the cloud.
Note: Teaching you Apps Script is outside of the scope of this lab. There are plenty of online resources. The official documentation features an overview with quickstarts, tutorials, as well as videos. This lab introduces you to the Apps Script development environment so you're comfortable creating code and get you thinking about the types of applications you can build with it.

Apps Script applications come in one of two forms:

  1. Bound—meaning it's forever, and only tied to one Google document (Doc, Sheet, Slide, Site, or Form)
  2. Standalone—an independent script not bound to Google Sheets, Docs, Slides or Forms file, or Google Sites.

Bound and Standalone apps can also be published to expose more broadly:

Your first Apps Script app should be bound to a Google Sheet. Time to create a new spreadsheet!

Task 1. Create a new Google Sheet and enter a street address

Enter a street address in a new Google Sheet by following these instructions:

  1. To create a new sheet, open Google Sheets.
  2. On the blank spreadsheet, click into the first cell in the upper left-hand corner (A1). It should be in column A and row 1.
  3. Enter an address in that cell, - pick any worldwide valid street address with a targeted location such as postal code or city and state/province, for example 76 9th Ave, New York.

That's all you have to do in the Sheet. Now you're ready to enter the editor and write some code!

Click Check my progress to verify that you've performed the above task.

Create a new Google Sheet and enter a street address

Task 2. Open Apps Script

Apps Script provides a code editor you use to create the Sheets bound script.

  • From the top menu bar, select Extensions > Apps Script.

Apps Script opens. Notice the code editor window on the right:

Apps Script project page displaying Code.gs in the code editor

A default function named myFunction() is automatically created for you, and in the editor. That's it... you're now ready to write your application.

Task 3. Edit the (template) code

  1. The file Code.gs provides "template" code and doesn't do much. Copy the code below and paste it in the editor window to replace the template code. Then update <YOUR_EMAIL> with lab provided user email:
function sendMap() { var sheet = SpreadsheetApp.getActiveSheet(); var address = sheet.getRange("A1").getValue(); var map = Maps.newStaticMap().addMarker(address); GmailApp.sendEmail("<YOUR_EMAIL>", "Map", 'See below.', {attachments:[map]}); }
  1. To restrict this app to access only the Sheet you're working with (as opposed to all of a user's Sheets), add this annotation as a file-level comment for the peace of mind of your users:
/** * @OnlyCurrentDoc */

You did it. Not counting the optional annotation, you just created sendMap(), a 4 line app.

Remember to replace <YOUR_EMAIL> with the user email provided by this lab so you can check for email messages during this lab.

Did you notice when you replaced the code in the editor, a red circle showed up to the left of the file name?

A red circle to the left of a file name in the UI

That means you've edited the file which now needs to be saved. You'll see it every time you have an unsaved edit.

  1. Save and name your project, call it anything you like—for example, "Hello Maps!". Save the file by clicking the Save project icon.

The Save project icon in the code editor menu bar

Alternatively, you can CTRL+S (PCs, Linux) or Command+S (Mac). You must name your project before you can proceed.

Task 4. Run the Google Sheets, Maps, and Gmail app

To run the app you created:

  1. Since the function was renamed to sendMap(), select the function to run as sendMap:

Code Editor menu bar displaying sendMap as the function to run

  1. Click Run in the Code Editor menu bar to run the sendMap() function.

Apps Script manages the authorization code, so you don't have to write it. App users, however, still need to grant permission to the script to access your Sheet and be able to send email through Gmail on your behalf. The first auth dialog looks like this:

Authorization dialog

  1. Click Review Permissions.
  2. If prompted, choose your account (your Username found in the Lab Details panel of the lab).

The student account highlighted in the Choose an account from qwiklabs.net dialog

  1. In the next dialog asking if your app can access your Google Account, click Allow.

After you grant permission, the script runs to completion.

  1. Hover over to the left side and click on Executions to see sendMap listed. Click View Dashboard if prompted.

Executions page listing the deployed sendMap funcion

  1. Click the Open Gmail button shown on the left side lab panel.

  2. In the Choose and account dialog, enter your student username and click Next.

  3. Enter the lab provided Password and click Next.

  4. Click Accept to accept the terms.

You should now be in Gmail, looking at your Inbox. You should find a message with Subject "Map" and a message body that looks like this:

Email message sent by the script, the subject is "Map" and the message body has a map.

Click Check my progress to verify that you've performed the above task.

Run the Google Sheets, Maps, and Gmail app

Just think about it... four lines of code that access three different Google products in a meaningful way, even though it's not a complete application by itself. Even if you're unfamiliar with JavaScript or Apps Script, the code should be readable enough to give you a rough idea how it works, and perhaps what Apps Script can accomplish for you.

Task 5. The App - a detailed explanation

This section reviews the code in more detail.

Since this application is short, there's no overall code structure to discuss. Instead,this section reviews each line of this app, which touches three different Google products!

This is a normal JavaScript function declaration for sendMap():

function sendMap() {

The first line of code calls the Spreadsheet Service accessible from Apps Script via the SpreadsheetApp object. The returned sheet is assigned to a variable of the same name.

The getActiveSheet() method does exactly what it says it does—it returns a "handle" to the current sheet that is active in the user interface (UI):

var sheet = SpreadsheetApp.getActiveSheet();

With the sheet object, reference the cell range (of a single cell) in A1 notation with getRange(). A "range" is a group of cells, including just a single one like yours... cell A1, the one you entered the address in.

Now fetch what's inside that range of cells with the getValue() call, and assigned it to the address variable upon return. Try adding more addresses and reading from different cells.

var address = sheet.getRange("A1").getValue();

The 3rd line connects to the Google Maps Service via the Maps object. As soon as you have access to the Maps Service, request that a new static map be created via newStaticMap().

You can then put a "pin" dropped onto the address you pulled from the Sheet by using the addMarker() method:

var map = Maps.newStaticMap().addMarker(address);

The last line uses the Mail Service (via the GmailApp object), calling its sendEmail() method, to send the email which includes both the text "See below." and the map image as an attachment:

GmailApp.sendEmail("friend@example.com", "Map", 'See below.', {attachments:[map]}); }

Congratulations!

You used the Google Apps Script to write code that accesses Google developer technologies to extract an address in Google Sheets, generate a Google Map based on that address, and sends the map to an email recipient.

Next steps / Learn more

Additional resources

The code featured in this lab is also available at its GitHub repo at GitHub.com/googlecodelabs/apps-script-intro. (This lab aims to stay in-sync with the repo.) Below are additional resources to help you dig deeper into the material covered in this lab as well as explore other ways of accessing Google developer tools programmatically.

Documentation

Related and general videos

News and updates

Google Cloud training and certification

...helps you make the most of Google Cloud technologies. Our classes include technical skills and best practices to help you get up to speed quickly and continue your learning journey. We offer fundamental to advanced level training, with on-demand, live, and virtual options to suit your busy schedule. Certifications help you validate and prove your skill and expertise in Google Cloud technologies.

Manual Last Updated November 05, 2024

Lab Last Tested November 05, 2023

Copyright 2025 Google LLC. All rights reserved. Google and the Google logo are trademarks of Google LLC. All other company and product names may be trademarks of the respective companies with which they are associated.

Prima di iniziare

  1. I lab creano un progetto e risorse Google Cloud per un periodo di tempo prestabilito
  2. I lab hanno un limite di tempo e non possono essere messi in pausa. Se termini il lab, dovrai ricominciare dall'inizio.
  3. In alto a sinistra dello schermo, fai clic su Inizia il lab per iniziare

Utilizza la navigazione privata

  1. Copia il nome utente e la password forniti per il lab
  2. Fai clic su Apri console in modalità privata

Accedi alla console

  1. Accedi utilizzando le tue credenziali del lab. L'utilizzo di altre credenziali potrebbe causare errori oppure l'addebito di costi.
  2. Accetta i termini e salta la pagina di ripristino delle risorse
  3. Non fare clic su Termina lab a meno che tu non abbia terminato il lab o non voglia riavviarlo, perché il tuo lavoro verrà eliminato e il progetto verrà rimosso

Questi contenuti non sono al momento disponibili

Ti invieremo una notifica via email quando sarà disponibile

Bene.

Ti contatteremo via email non appena sarà disponibile

Un lab alla volta

Conferma per terminare tutti i lab esistenti e iniziare questo

Utilizza la navigazione privata per eseguire il lab

Utilizza una finestra del browser in incognito o privata per eseguire questo lab. In questo modo eviterai eventuali conflitti tra il tuo account personale e l'account Studente, che potrebbero causare addebiti aggiuntivi sul tuo account personale.