/aiospread

Google Spreadsheets Asyncio Python API

Primary LanguagePythonOtherNOASSERTION

Google Spreadsheets Python API

This Sheets API was made by some random dude who wants to learn more about asyncio.

BE CAREFUL WITH THIS AS IT'S EXPERIMENTAL.

These docs may not even be correct so gl

Manage your spreadsheets with aiospread in Python.

Fork of gspread

Features:

  • Google Sheets API v4.
  • Open a spreadsheet by its title or url.
  • Extract range, entire row or column values.
  • Python 3 support.
  • Asyncio support

Basic Usage

  1. Obtain OAuth2 credentials from Google Developers Console

  2. Start using gspread:

import aiohttp

gc = aiohttp.authorize(credentials)

# Open a worksheet from spreadsheet with one shot
async def opensht():
    wks = await gc.open("Where is the money Lebowski?").sheet1

    await wks.update_acell('B2', "it's down there somewhere, let me take another look.")

    cell_list = await wks.range('A1:B7')

asyncio.get_event_loop().run_until_complete(opensht())

More Examples

Opening a Spreadsheet

async def opensheets():
    # You can open a spreadsheet by its title as it appears in Google Docs
    sh = await gc.open('My poor gym results') # <-- Look ma, no keys!

    # If you want to be specific, use a key (which can be extracted from
    # the spreadsheet's url)
    sht1 = await gc.open_by_key('0BmgG6nO_6dprdS1MN3d3MkdPa142WFRrdnRRUWl1UFE')

    # Or, if you feel really lazy to extract that key, paste the entire url
    sht2 = await gc.open_by_url('https://docs.google.com/spreadsheet/ccc?key=0Bm...FE&hl')

Selecting a Worksheet

async def selectors():
    # Select worksheet by index. Worksheet indexes start from zero
    worksheet = await sh.get_worksheet(0)

    # By title
    worksheet = await sh.worksheet("January")

    # Get a list of all worksheets
    worksheet_list = await sh.worksheets()

Creating a Worksheet

async def creation():
    worksheet = await sh.add_worksheet(title="A worksheet", rows="100", cols="20")

Deleting a Worksheet

async def deletion():
    await sh.del_worksheet(worksheet)

Getting a Cell Value

async def values():
    # With label
    val = await worksheet.acell('B1').value

    # With coords
    val = await worksheet.cell(1, 2).value

    # To get a cell formula
    cell = await worksheet.acell('B1') # or .cell(1, 2)

Getting All Values From a Row or a Column

async def hashing():
    # Get all values from the first row
    values_list = await worksheet.row_values(1)

    # Get all values from the first column
    values_list = await worksheet.col_values(1)

Getting All Values From a Worksheet as a List of Lists

async def alls():
    list_of_lists = await worksheet.get_all_values()

Finding a Cell

# Find a cell with exact string value
async def finding():
    cell = worksheet.find("Dough")

    print("Found something at R%sC%s" % (cell.row, cell.col))

    # Find a cell matching a regular expression
    amount_re = re.compile(r'(Big|Enormous) dough')
    cell = worksheet.find(amount_re)

Finding All Matched Cells

async def matching():
    # Find all cells with string value
    cell_list = await worksheet.findall("Rug store")

    # Find all cells with regexp
    criteria_re = re.compile(r'(Small|Room-tiering) rug')
    cell_list = await worksheet.findall(criteria_re)

Cell Object

Each cell has a value and coordinates properties.

value = cell.value
row_number = cell.row
column_number = cell.col

Updating Cells

await worksheet.update_acell('B1', 'Bingo!')

# Or
await worksheet.update_cell(1, 2, 'Bingo!')

# Select a range
cell_list = worksheet.range('A1:C7')

for cell in cell_list:
    cell.value = 'O_o'

# Update in batch
await worksheet.update_cells(cell_list)

Installation

Requirements

Python 3.6+

Using PIP

pip install git+https://RainbowLegend/aiospread.git

From GitHub

git clone https://github.com/RainbowLegend/aiospread.git
cd aiospread
python setup.py install

Documentation

How to Contribute

Please make sure to take a moment and read the Code of Conduct.

Ask Questions

The best way to get an answer to a question is to ask on Stack Overflow with a gspread tag.

Report Issues

Please report bugs and suggest features via the GitHub Issues.

Before opening an issue, search the tracker for possible duplicates. If you find a duplicate, please add a comment saying that you encountered the problem as well.

Contribute code

Please make sure to read the Contributing Guide before making a pull request.