Skip to main content

Tool for syncing bank transaction data to Google Sheets with Plaid.

Project description

GSheets-Plaid

A spring break project to get my bank transaction data in Google Sheets without using Google Apps Script.

Usage

Prerequisites

Installation

Using a virtualenv is a good idea.

python3 -m pip install gsheets-plaid

Create a Google Cloud project and enable the Google Sheets API

Follow this tutorial

Be sure to enable the "Google Sheets API"

Create access credentials for Google

Follow this tutorial for creating OAuth client ID credentials for your Google account.

  • Choose "Desktop app" in the tutorial

OAuth consent screen

Before Google Cloud Platform will let you create OAuth client ID credentials, it will make you complete the OAuth consent screen. Fill out the required fields with your personal email, and choose an arbitrary application name. Since we aren't planning on publishing this app, it doesn't really matter.

On the "Scopes" step, add the following scope: https://www.googleapis.com/auth/drive.file. You can use the search feature and look up drive.file to quickly find the right scope.

On the "Test users" page, add the google account email that corresponds with the account you want to have the finance tracker saved on.

Back to creating OAuth credentials

Here is a summary of how to create the credentials:

  1. Click "Create credentials"
  2. Click "OAuth client ID"
  3. Select "Desktop app"
  4. Type a name of your choice
  5. Click the download icon (when you hover it says "Download OAuth Client")
  6. Click "Download JSON"

Create a Plaid Developer account

Create a Plaid developer account here.

After you have created an account, go to Team Settings > Keys. You should see your client_id, as well as Development and Sandbox secrets.

Configure gsheets_plaid

To configure gsheets_plaid with all of these credentials we just created, run the following command:

python3 -m gsheets_plaid init

You will be given the opportunity to enter all the credentials necessary for syncing with Plaid and Google Sheets. Note that you only need to supply the Plaid secret corresponding to the Plaid environment that gsheets_plaid runs in. In other words, you can just submit the Plaid sandbox secret and leave the development and production ones blank to start out. You can always come back and rerun init to update the config.

When it asks for the Google credentials JSON file, supply the absolute filepath to the JSON file we downloaded previously. Once you see that it is successfully saved, you can safely delete the copy of the credentials file from your downloads folder (or wherever you saved it).

Link a bank account

We are finally getting to the exciting part!

If everything is configured correctly, running the following command will open a new browser tab with a small local web server you can use to connect a bank account.

python3 -m gsheets_plaid link

If you are using the sandbox environment, note that the credentials are provided at the bottom of the screen. If you are using the development environment, use your actual bank account credentials. Note that you are only given 5 tokens to use in the development environment, but if you submit a ticket on Plaid Dashboard, you can get it bumped up to 100 tokens, which should be more than plenty for personal usage.

Once you have added all the bank accounts you want, close the browser tab and enter CTRL+C to kill the web server process.

Sync transaction data with Google Sheets

To sync your transactions from the banks you signed in with, run this command in the terminal

python3 -m gsheets_plaid sync

If this is the first time you're running the command, you'll see a new browser tab open and be asked to give this developer application permission to use Google Sheets. You should only have to do this once. A new finance tracker spreadsheet will be created and the transaction data will be synced to Sheet1. Subsequent runs of this command will reuse the same spreadsheet.

That's it! Hopefully you're inspired to write some cool formulas and make neat charts using this raw transaction data.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

gsheets-plaid-0.0.3.tar.gz (1.5 MB view details)

Uploaded Source

Built Distribution

gsheets_plaid-0.0.3-py3-none-any.whl (1.7 MB view details)

Uploaded Python 3

File details

Details for the file gsheets-plaid-0.0.3.tar.gz.

File metadata

  • Download URL: gsheets-plaid-0.0.3.tar.gz
  • Upload date:
  • Size: 1.5 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.10.3

File hashes

Hashes for gsheets-plaid-0.0.3.tar.gz
Algorithm Hash digest
SHA256 1a8ffdfad803c6a1c8f246382afbbbe75bec3e20a6472202fa6ac6f8d75a6bde
MD5 7b4624e045e24fac619dfcd09cdc2136
BLAKE2b-256 f361b093b36d60325aedfad9bce7ca66648b80852baf8e21dfe62e8a9825ff7e

See more details on using hashes here.

File details

Details for the file gsheets_plaid-0.0.3-py3-none-any.whl.

File metadata

File hashes

Hashes for gsheets_plaid-0.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 5c9a2b272bd261aca8761ca699bcce8ec9faf75d2469a80f45f7afa1be37db87
MD5 14eac8fc63357b09fb1cae9202b6cc1d
BLAKE2b-256 30b2ecfbdcb5cfa3847768ca1262d3221a2cdfdc25ecc499b0c30036218758a3

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page