Google Sheets Authentication
Authenticating to Google Sheets
To authenticate with Google Sheets, start by creating a Service Account by going to https://console.cloud.google.com/iam-admin/serviceaccounts.
data:image/s3,"s3://crabby-images/0da8a/0da8a020c14d485fbdf340c616afbac95e75269e" alt="Messages Image(1427895882).png 2798"
Keep track of the Service account ID. You will use this when you need to grant access to Google Sheets.
Next, go to the Service account details and click Create private key for your service account.
Set the Key type to be JSON
and download the key.
data:image/s3,"s3://crabby-images/20b70/20b7026172ffe310e92a5b67aa2cdc50e8dd3075" alt="Messages Image(2758524934).png 2808"
When creating a new Google Sheets Resource in DataSiv, paste the JSON contents of the secret key file into the Service Account field. Make sure to set the Service Account Scopes to ["https://www.googleapis.com/auth/drive"].
Your resource might look something like this:
data:image/s3,"s3://crabby-images/b4ca4/b4ca443abc9b3ebdf86e77c1361938ab70d97ce9" alt="Messages Image(3202548454).png 1182"
When writing queries that read or write to existing Google Sheets (such as the query below), make sure to grant access to the Service Account ID to the sheet.
For example, if you had datasiv@datasiv.iam.gserviceaccount.com
as your Service Account ID, and you wanted to grant access to Spreadsheet ID 1r6ytlatXh78rji9uYq4Y8KVggrdpn6kXFol_0cfeCWk
, you'd go to https://docs.google.com/spreadsheets/d/1r6ytlatXh78rji9uYq4Y8KVggrdpn6kXFol_0cfeCWk/edit#gid=1618853414
click Share at the top right, and add the email as you would with a regular user.
data:image/s3,"s3://crabby-images/0eeab/0eeab28a76f2ea4d7d24aac80889f37bef0c1b8e" alt="Messages Image(2563844202).png 3264"
data:image/s3,"s3://crabby-images/8bc57/8bc57d3777d8514649b84c5de477f8e12b6efb94" alt="Messages Image(3980504754).png 2670"
To enable write access, grant the service account write permissions.
Congratulations! You are now able to read and write from Google Sheets using DataSiv.
Updating existing rows in Google Sheets
When writing back to Google Sheets, there's two main options, adding new rows and updating an existing row.
As this comes up quite often, this guide demonstrates how to update an existing row and column, from a table.
Suppose you're reading from Sheet1!A1:E1000, and you're using the first row as a header, so you're displaying the following query in a table.
data:image/s3,"s3://crabby-images/7220d/7220d9d681ddf7071cc8816ddf4eea44a3d2c519" alt="Messages Image(3432986681).png 2530"
To update the Google Sheet, you'll need to reference the current row in a table. However, tables are zero indexed (first row is at index 0), while your grid in Google Sheets starts at row 2 because row 1 is the header. Therefore, you'll use something similar to the following transform to display the data in the table instead:
data:image/s3,"s3://crabby-images/41a02/41a02f911309e91886fa85d271580ca4a986f18d" alt="Messages Image(3543912148).png 3310"
Finally, in the Google Sheets query that updates the row that a user selected, you'll reference the googleSheetsIndex
column of the Selected Row of the table, as follows:
data:image/s3,"s3://crabby-images/d8c7e/d8c7ee0c5cf513aa211d35c4e9bdfc25bdab6882" alt="Messages Image(2937447243).png 2562"
For example, this query updates the first two column (A, B) to be the values [1,2], on the row that the user selected in the table.
Updated over 4 years ago
See some tutorials on how to read and write to Google Sheets here: