Skip to content

Latest commit

 

History

History
74 lines (53 loc) · 2.85 KB

README.md

File metadata and controls

74 lines (53 loc) · 2.85 KB

Google Sheets Tools

G Sheets Tools is a wrapper for the Google Sheets API that streamlines the process of moving data in and out of Sheets, especially for Pandas users. (I built this because I got tired of exporting and uploading .csv files.)

A note about terminology ...

In this document, the main spreadsheet is a SHEET and the pages within the spreadsheet are PAGES. This is inconsistant with Google's own terminology but it's less confusing.

Before you install...

This package allows you to interface with your Google Sheets docs, but you still need to make a dummy Google App that runs the Sheets API to use it. It's easy! Here's how.

  1. Go to the Google Developers Console. Create a new app.
  2. Go to the Google API Library and find the Google Sheets API.
  3. Click "Enable"
  4. Go to the Credentials page, either through the provided link or the in the console sidebar.
  5. Follow the prompt to open the OAuth Consent Screen and name your app. (This is the only thing you need to do on this page!)
  6. Click "+ Create Credentials" at the top of the screen and select "OAuth client ID".
  7. Select "Desktop app" from the "Application type" menu and put whatever you like in "Name".
  8. You should now see your OAuth Client ID on the Credentials page.
  9. Click the arrow on the right side of the menu to download your credentials in JSON form.
  10. Move the credentials to ~/.config/gst.

Installation

To install with pip, run

pip install g_sheets_tools

You can also clone this repository and run python setup.py install.

Basic Usage

Make a gSheet object:
Duplicate names are OK, Sheets automatically assigns unique ID's.

# pass a sheet id (the alphanumerical code from the sheet url) to load an existing spreadsheet
g = gSheet(sheet_id='1pMvgod2nteAIIRJbplMqkllLaXpK15_046Zz_82b4zg')

# ... or pass a whole url
g = gsheet(sheet_id="https://docs.google.com/spreadsheets/d/1NUyOxbJF4cEUGfT0SEUzDk4Tcg11qCCI9IgU9LDFDD8/edit#gid=542492911")

# ...or pass a name to create a new spreadsheet
g = gSheet(name='new spreadsheet')

Download data with a gSheet object:
Data ranges are formatted "Sheet Name!first cell:last cell".

# pass a data range
data = g.load_from_range('cities!A:Z')

Upload data with a gSheet object:
This overwrites data by default. Pass write_setting='append' to preserve existing data.

# pass a dataframe and a destination
new_cities_df = pd.read_csv('new_cities.csv)
g.write_to_page(new_cities_df, 'cities!A:Z')

Other Functions

# create a new page within the spreadsheet
g.create_new_page('new page name')

# rename an existing page
g.rename_page('current page name', 'new page name')

# delete a sheet
g.delete_page('page to delete')