Coder Social home page Coder Social logo

goshdb's Introduction

goshdb

GOogle SHeets DataBase - Python client to key-value database based on Google Sheets

Sheet works as a table and has the following look & structure:

Use cases

  • Store configuration with ability to change it on the fly
  • Store data that should be shared between multiple users / machines
  • Write status of a long-running process and observe it in real-time in Google Sheets
  • Review data modification history in Google Sheets UI (File -> Version history -> See version history)

Features

  • Simple key-value interface (get/set string/object)

Advantages

  • Free storage (Google Sheets API has free quota)
  • Concurrent read (Supports parallel read from multiple clients)
  • No need to create a server
  • User-friendly Google Sheets UI for data review & modification
  • No need to install any software on the client side (only Python)
  • Simple get/set methods instead of SQL queries
  • No need to create a database schema (just create a new sheet)
  • Data backup, synchronization, availability, and security are managed by Google Sheets

Limitations

  • Not suitable for high-frequency read/write operations (Google Sheets API has read/write quota: 300/minute per project, 60/minute per user per project)
  • Not suitable for concurrent write (Google Sheets API has no locking mechanism)
  • Not suitable for very large data (Google Sheets has a limit of 10 million cells per spreadsheet, i.e. 5 million key-value pairs
  • Not suitable for high-speed data access (Google Sheets API has a delay, takes ~0.3-1 second per get/set operation)
  • Not suitable for complex queries, types, data structures, relations, validation and indexing (only key-value interface)
  • Not suitable for sensitive & high-security data (Google Sheets API has access to all spreadsheets in the account)

Installation

pip install goshdb

Configuration

See this video for step-by-step instruction & demo

Step 1. Select a Google account that will be used to access the spreadsheet

Details
  • Though Table uses only provided spreadsheet, credentials technically allow to read/write all the spreadsheets in the account.
  • So it's recommended to use Table with a special service (non-personal) account that doesn't have critical/secret spreadsheets that might be compromised.

Step 2. Create a spreadsheet in your Google Sheets account.

Details
  • You should share the spreadsheet and provide write access to the account that will be used to access it (see Step 1).

Step 3. Obtain credentials.json file with this the instruction

Details
  • If you do this for the first time - take credentials.json and put it in secret_dir.
  • On a first attempt to create Table it'll open a browser window, ask you to sign in the target test account.
  • Then the token.json file will be generated automatically and put in secret_dir.
  • The token.json file will be used automatically for further access to the target spreadsheet.
  • You can use token.json to access the spreadsheet from another machine without completing the steps above

Usage

from goshdb import authenticate, Table
from pathlib import Path

# Take spreadsheet ID from your spreadsheet URL:
# https://docs.google.com/spreadsheets/d/[SPREADSHEET_ID]/edit#gid=0
SPREADSHEET_ID = '...'
# Provide a sheet name. It should be either new sheet or existing one that follows the required structure.
SHEET_NAME = '...'  

# Authenticate
creds = authenticate(Path('path/to/secret_dir'))
# Create a Table object. If you do this for the first time - it'll open a browser window (see Step 3 details)
table = Table(
    creds=creds,
    spreadsheet_id=SPREADSHEET_ID,
    table_name=SHEET_NAME
)

# Write a key-value pair
table.set_string('city', 'London')
print(table.get_string('city'))  # London
table.set_object('person_1', {'name': 'John', 'age': 30})
print(table.get_object('person_1'))  # {'name': 'John', 'age': 30}

goshdb's People

Contributors

artoby avatar

Stargazers

 avatar  avatar  avatar

Watchers

 avatar

Forkers

maxsheer

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.