Google Sheets
Google Sheets is a web-based spreadsheet program that is part of Google's free, web-based Google Docs Editors suite.
ingestr supports Google Sheets as a source.
URI format
The URI format for Google Sheets is as follows:
gsheets://?credentials_path=/path/to/service/account.json
Alternatively, you can use base64 encoded credentials:
gsheets://?credentials_base64=<base64_encoded_credentials>
URI parameters:
credentials_path
: the path to the service account JSON file
The URI is used to connect to the Google Sheets API for extracting data.
Setting up a Google Sheets integration
Google Sheets requires a few steps to set up an integration, please follow the guide dltHub has built here.
Once you complete the guide, you should have a service account JSON file and the spreadsheet ID to connect to. Let's say:
- you store your JSON file at the path
/path/to/file.json
. - the spreadsheet you'd like to connect to has the ID
fkdUQ2bjdNfUq2CA
. For example, if your spreadsheet URL ishttps://docs.google.com/spreadsheets/d/fkdUQ2bjdNfUq2CA/edit?pli=1&gid=0#gid=0
, then the spreadsheet ID isfkdUQ2bjdNfUq2CA
. - the sheet inside the spreadsheet is
Sheet1
.
Based on this assumption, here's a sample command that will copy the data from the Google Sheets spreadsheet into a DuckDB database:
ingestr ingest --source-uri 'gsheets://?credentials_path=/path/to/file.json' --source-table 'fkdUQ2bjdNfUq2CA.Sheet1' --dest-uri duckdb:///gsheets.duckdb --dest-table 'dest.output'
The result of this command will be a table in the gsheets.duckdb
database.
CAUTION
Google Sheets does not support incremental loading, which means every time you run the command, it will copy the entire spreadsheet from Google Sheets to the destination. This can be slow for large spreadsheets.