Manage your spreadsheets with gspread in Python.
Features:
- Open a spreadsheet by its title or url.
 - Extract range, entire row or column values.
 - Independent of Google Data Python client library.
 - Python 3 support.
 
import gspread
# Login with your Google account
gc = gspread.login('[email protected]', 'password')
# Open a worksheet from spreadsheet with one shot
wks = gc.open("Where is the money Lebowski?").sheet1
wks.update_acell('B2', "it's down there somewhere, let me take another look.")
# Fetch a cell range
cell_list = worksheet.range('A1:B7')# You can open a spreadsheet by its title as it appears in Google Docs
sh = 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 = gc.open_by_key('0BmgG6nO_6dprdS1MN3d3MkdPa142WFRrdnRRUWl1UFE')
# Or, if you feel really lazy to extract that key, paste the entire url
sht2 = gc.open_by_url('https://docs.google.com/spreadsheet/ccc?key=0Bm...FE&hl')# Select worksheet by index. Worksheet indexes start from zero
worksheet = sh.get_worksheet(0)
# Most common case: Sheet1
worksheet = sh.sheet1worksheet = sh.add_worksheet(title="A worksheet", rows="100", cols="20")sh.del_worksheet(worksheet)# With label
val = worksheet.acell('B1').value
# With coords
val = worksheet.cell(1, 2).value# Get all values from the first row
values_list = worksheet.row_values(1)
# Get all values from the first column
values_list = worksheet.col_values(1)list_of_lists = worksheet.get_all_values()# Find a cell with exact string value
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)# Find all cells with string value
cell_list = worksheet.findall("Rug store")
# Find all cells with regexp
criteria_re = re.compile(r'(Small|Room-tiering) rug')
cell_list = worksheet.findall(criteria_re)Each cell has a value and coordinates properties.
value = cell.value
row_number = cell.row
column_number = cell.colworksheet.update_acell('B1', 'Bingo!')
# Or
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
worksheet.update_cells(cell_list)Python 2.6+ or Python 3+
git clone https://github.com/burnash/gspread.git
cd gspread
python setup.py installpip install gspreadIf you're on easy_install, it's:
easy_install gspreadAt this time gspread will not work if you have Two Factor Authorization turned on for your account. See #45 for details.
The library is in active development so any feedback is urgently needed. Please don't hesitate to open up a new github issue or simply drop me a line to [email protected].
