These are Google Apps Scripts for syncing data between a Coda doc and a Google Sheets file. The scripts supports adding, deleting, and updating rows of data in your target Coda doc or Google Sheet. List of the scripts in this repo:
- coda_to_coda.js - Sync data from tables in one Coda doc to tables in another Coda doc (gist)
- sheets_to_sheets.js - Sync data from one Google Sheet to another Google Sheet (gist)
- coda_to_sheets.js - Sync data from a table in a Coda doc to a worksheet in Google Sheets (gist)
- sheets_to_coda.js - Sync data from a worksheet in Google Sheets to a table in a Coda doc (gist)
Starting in line 9 to line 14 of the coda_to_sheet.js script, you'll need to enter in some of your own data to make the script work. Step-by-step:
- Go to script.google.com and create a new project and give your project a name.
- Go to Libraries then Resources and paste the following string of text/numbers into the library field:
15IQuWOk8MqT50FDWomh57UqWGH23gjsWVWYFms3ton6L-UHmefYHS9Vl
. - Click Add and then select version 9 of library to use (as of August 2020, version 9 - Coda API v1.0.0 is the latest)
- Copy and paste the entire script into your Google Apps Script project and click File then Save.
- Go to your Coda account settings, scroll down until you see "API SETTINGS" and click Generate API Token. Copy and paste that API token into the value for
YOUR_API_KEY
in the script. Note: do not delete the single apostrophes aroundYOUR_API_KEY
. - Get the the doc ID from your Coda doc by copying and pasting all the characters after the
_d
in the URL of your Coda doc (should be about 10 characters). You can also use the Doc ID Extractor tool in the Coda API docs. Copy and paste your doc ID intoYOUR_SOURCE_DOC_ID
. - Go back to your account settings and scroll down to the very bottom until you see "Labs." Toggle "Enable Developer Mode" to ON.
- Hover over the table name in your Coda doc and click on the 3 dots that show up next to your table name. Click on "Copy table ID" and paste this value into
YOUR_SOURCE_TABLE_ID
. - To get your Google Sheets ID, get all the characters after
/d/
in your Google Sheets file up until the slash and paste this intoYOUR_GOOGLE_SHEETS_ID
. See this link for more info. - Write in the name of the worksheet from your Google Sheets file where data will be sycned into in the
YOUR_GOOGLE_SHEETS_WORKSHEET_NAME
value. - In Google Sheets, create a new column name at the end of your column headers called something like
Coda Source Row URL
and make sure there is no data in that column below the header. Write that column name inYOUR_SOURCE_ROW_URL_COLUMN_NAME
. - Go back to Google Apps Script, click on the Select function dropdown in the toolbar, and select
runSync
. Then click the play▶️ button to the left of the bug 🐞 button. This should copy over all the data from your Coda doc to Google Sheets. - To get the script to run every minute, hour, or day, click on the clock 🕒 button to the left of the
▶️ button to create a time-driven trigger. - Click Add Trigger, make sure
runSync
is set as the function to run, "Select event source" should beTime-driven
, and play around with the type of time based trigger that fits your needs. I like to set the "Failure notification settings" toNotify me immediately
so I know when my script fails to run.
Most of the steps above apply to the sheets_to_coda.js script as well but there are few extra features.
- You can follow steps 1-10 above to fill out line 12 to line 18 in the script (except line 14 mentioned in the next step). The main difference is that "SOURCE" and "TARGET" are flipped around since you are now syncing from a source Google Sheet to a target Coda doc.
- Your Coda table cannot have a column named
Coda Row ID
. If you need to use a column with this name, replace theTARGET_ROW_ID_COLUMN
variable with another value. - If you have edit access to the Google Sheet, follow step 11 above and write in the column name in
YOUR_SOURCE_ROW_URL_COLUMN_NAME
. - If you want the ability to add rows to your Coda table and NOT have these rows deleted every time the sync runs, create a column in your Coda table and name it
Do not delete
. This column should be a checkbox column format and you will check the box for every row you manually add to your Coda table that you want to keep in that table. Otherwise, the script will delete that row and always keep the Coda table a direct copy of what's in your Google Sheets file. If you change the name of thisDo not delete
column, you must edit the value of theDO_NOT_DELETE_COLUMN
variable in line 22 of the script as well. - If you want the script to completely delete and re-write the rows in your Coda table each time the script runs, set the
REWRITE_CODA_TABLE
totrue
in line 23. This may make the script run faster, but may not be faster for larger tables (few thousand rows). For Google Sheets files where you only have view-only access, this setting will automatically get set totrue
. - Follow steps 12-14 in the Coda to Google Sheets section above to set up your time-driven trigger.
You can follow steps 1-8 in the Coda to Google Sheets section above to get the values you need for the coda_to_coda.js script. The only thing you need to add is a column in your target Coda table (the table where data is getting synced into) called Source Row URL
. If you change the name of this column, you must change the value of the TARGET_TABLE_SOURCE_ROW_COLUMN
variable in line 5 of the script.
- When possible, keep the column names between your Coda doc and Google Sheet the same. There are some exceptions to this which are mentioned in the blog post.
- You will have to set up a time-driven installable trigger in Google App Scripts to get the scripts to run every minute, hour, etc.
- For syncing data from a Google Sheet to Coda, you must have edit or view access to the Google Sheet
- You cannot sort data in the Google Sheet if syncing from Sheets to Coda (read blog post for more detail)
- Formulas you write in Coda or Google Sheets will get lost when synced to the target
Here are a few blog posts explaining how the scripts work. For syncing data Coda to Coda and Sheets to Sheets, read this tutorial. For sycning data between Coda and Google Sheets, read this tutorial. Here are a few YouTube tutorials on how to setup and use the scripts: