Skip to main content

Extending Gsheets for added functionalities

Project description

gsheetsplus

gsheetsplus is an extension over the gsheets library to provide added functionalities like plotting graphs between two axis.

Turn on the API, download an OAuth client ID as JSON file, and create a Sheets object from it. Use its index access (__getitem__) to retrieve SpreadSheet objects by their id, or use .get() with a sheet URL. Iterate over the Sheets object for all spreadsheets, or fetch spreadsheets by title with the .find() and .findall() methods.

SpreadSheet objects are collections of WorkSheets, which provide access to the cell values via spreadsheet coordinates/slices (e.g. ws['A1']) and zero-based cell position (e.g. ws.at(0, 1)).

Links

Installation

This package runs under 3.8+, use pip to install:

pip install gsheetsplus

This will also install gsheets, matplotlib and their dependencies.

Quickstart

Log into the Google Developers Console with the Google account whose spreadsheets you want to access. Create (or select) a project and enable the Drive API and Sheets API (under Google Apps APIs).

Go to the Credentials for your project and create New credentials > OAuth client ID > of type Other. In the list of your OAuth 2.0 client IDs click Download JSON for the Client ID you just created. Save the file as client_secrets.json in your home directory (user directory). Another file, named storage.json in this example, will be created after successful authorization to cache OAuth data.

On you first usage of gsheets with this file (holding the client secrets), your webbrowser will be opened, asking you to log in with your Google account to authorize this client read access to all its Google Drive files and Google Sheets.

Create a sheets object:

>>> from gsheets import Sheets

>>> sheets = Sheets.from_files('~/client_secrets.json', '~/storage.json')
>>> sheets  #doctest: +ELLIPSIS
<gsheets.api.Sheets object at 0x...>

Fetch a spreadsheet by id or url:

# id only
>>> sheet['1dR13B3Wi_KJGUJQ0BZa2frLAVxhZnbz0hpwCcWSvb20']
<SpreadSheet 1dR13...20 u'Spam'>

# id or url
>>> url = 'https://docs.google.com/spreadsheets/d/1dR13B3Wi_KJGUJQ0BZa2frLAVxhZnbz0hpwCcWSvb20'
>>> s = sheets.get(url)  
>>> s
<SpreadSheet 1dR13...20 u'Spam'>

Access worksheets and their values:

# first worksheet with title
>>> s.find('Tabellenblatt2')
<WorkSheet 1747240182 u'Tabellenblatt2' (10x2)>

# worksheet by position, cell value by index
>>> s.sheets[0]['A1']
u'spam'

# worksheet by id, cell value by position
>>> s[1747240182].at(row=1, col=1)
1

Dump a worksheet to a CSV file:

>>> s.sheets[1].to_csv('Spam.csv', encoding='utf-8', dialect='excel')

Dump all worksheet to a CSV file (deriving filenames from spreadsheet and worksheet title):

>>> csv_name = lambda infos: '%(title)s - %(sheet)s.csv' % infos
>>> s.to_csv(make_filename=csv_name)

Load the worksheet data into a pandas DataFrame (requires pandas):

>>> s.find('Tabellenblatt2').to_frame(index_col='spam')
        eggs
spam      
spam  eggs
...

WorkSheet.to_frame() passes its kwargs on to pandas.read_csv()

Plot graph between two axis(requires pandas):

>>> df = s.find("Sheet1").to_frame()
>>> sheets.plot(df, "offer_price", "average_sales", "graph")
>>> plt.show()

Detailed documentation for Gsheets can be found here.

See also

  • gsheets Base library for gsheetsplus
  • gsheets.py self-containd script to dump all worksheets of a Google Spreadsheet to CSV or convert any subsheet to a pandas DataFrame (Python 2 prototype for this library)
  • gspread Google Spreadsheets Python API (more mature and featureful Python wrapper, currently using the XML-based legacy v3 API)
  • example Jupyter notebook using gspread to fetch a sheet into a pandas DataFrame
  • df2gspread Transfer data between Google Spreadsheets and Pandas (build upon gspread, currently Python 2 only, GPL)
  • pygsheets Google Spreadsheets Python API v4 (v4 port of gspread providing further extensions)
  • gspread-pandas Interact with Google Spreadsheet through Pandas DataFrames
  • pgsheets Manipulate Google Sheets Using Pandas DataFrames (independent bidirectional transfer library, using the legacy v3 API, Python 3 only)
  • PyDrive Google Drive API made easy (google-api-python-client wrapper for the Google Drive API, currently v2)

License

This package is distributed under the MIT license.

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

gsheetsplus-0.3.5.tar.gz (4.5 kB view details)

Uploaded Source

Built Distribution

gsheetsplus-0.3.5-py3-none-any.whl (5.5 kB view details)

Uploaded Python 3

File details

Details for the file gsheetsplus-0.3.5.tar.gz.

File metadata

  • Download URL: gsheetsplus-0.3.5.tar.gz
  • Upload date:
  • Size: 4.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.4.2 requests/2.22.0 setuptools/50.3.1 requests-toolbelt/0.8.0 tqdm/4.30.0 CPython/3.8.2

File hashes

Hashes for gsheetsplus-0.3.5.tar.gz
Algorithm Hash digest
SHA256 80e2bcfab3e9b576f450ba1fdfe34d8a13c2333244f3b3adb7b849a05262fb7e
MD5 d3e0e50d6bd7072b050b8ee05068d907
BLAKE2b-256 660a9dc50ab3093c966e89c709dc08731701c8b92255ba50dda838e999cfdd50

See more details on using hashes here.

File details

Details for the file gsheetsplus-0.3.5-py3-none-any.whl.

File metadata

  • Download URL: gsheetsplus-0.3.5-py3-none-any.whl
  • Upload date:
  • Size: 5.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.4.2 requests/2.22.0 setuptools/50.3.1 requests-toolbelt/0.8.0 tqdm/4.30.0 CPython/3.8.2

File hashes

Hashes for gsheetsplus-0.3.5-py3-none-any.whl
Algorithm Hash digest
SHA256 4dca3fb762d568a99699dde790eacc5e4fcf1fb378d043512435a87b6c65cb17
MD5 ce1dd897fafd89fd885599fdcf868ed1
BLAKE2b-256 6eac6f5d9820176305abe6e25be07e068c591e6ae606e36e9367413d594ba59d

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