GoogleSheetsTools enable an Agent to interact with Google Sheets API for reading, creating, updating, and duplicating spreadsheets.

Prerequisites

You need to install the required Google API client libraries:
pip install google-api-python-client google-auth-httplib2 google-auth-oauthlib
Set up the following environment variables:
export GOOGLE_CLIENT_ID=your_client_id_here
export GOOGLE_CLIENT_SECRET=your_client_secret_here
export GOOGLE_PROJECT_ID=your_project_id_here
export GOOGLE_REDIRECT_URI=your_redirect_uri_here

How to Get Credentials

  1. Go to Google Cloud Console (https://console.cloud.google.com)
  2. Create a new project or select an existing one
  3. Enable the Google Sheets API:
    • Go to “APIs & Services” > “Enable APIs and Services”
    • Search for “Google Sheets API”
    • Click “Enable”
  4. Create OAuth 2.0 credentials:
    • Go to “APIs & Services” > “Credentials”
    • Click “Create Credentials” > “OAuth client ID”
    • Go through the OAuth consent screen setup
    • Give it a name and click “Create”
    • You’ll receive:
      • Client ID (GOOGLE_CLIENT_ID)
      • Client Secret (GOOGLE_CLIENT_SECRET)
    • The Project ID (GOOGLE_PROJECT_ID) is visible in the project dropdown at the top of the page

Example

The following agent will use Google Sheets to read and update spreadsheet data.
cookbook/tools/googlesheets_tools.py
from agno.agent import Agent
from agno.tools.googlesheets import GoogleSheetsTools

SAMPLE_SPREADSHEET_ID = "1BxiMVs0XRA5nFMdKvBdBZjgmUUqptlbs74OgvE2upms"
SAMPLE_RANGE_NAME = "Class Data!A2:E"

google_sheets_tools = GoogleSheetsTools(
    spreadsheet_id=SAMPLE_SPREADSHEET_ID,
    spreadsheet_range=SAMPLE_RANGE_NAME,
)

agent = Agent(
    tools=[google_sheets_tools],
    instructions=[
        "You help users interact with Google Sheets using tools that use the Google Sheets API",
        "Before asking for spreadsheet details, first attempt the operation as the user may have already configured the ID and range in the constructor",
    ],
)
agent.print_response("Please tell me about the contents of the spreadsheet")

Toolkit Params

ParameterTypeDefaultDescription
scopesOptional[List[str]]NoneCustom OAuth scopes. If None, uses write scope by default.
spreadsheet_idOptional[str]NoneID of the target spreadsheet.
spreadsheet_rangeOptional[str]NoneRange within the spreadsheet.
credsOptional[Credentials]NonePre-existing credentials.
creds_pathOptional[str]NonePath to credentials file.
token_pathOptional[str]NonePath to token file.
oauth_portint0Port to use for OAuth authentication.
enable_read_sheetboolTrueEnable reading from a sheet.
enable_create_sheetboolFalseEnable creating a sheet.
enable_update_sheetboolFalseEnable updating a sheet.
enable_create_duplicate_sheetboolFalseEnable creating a duplicate sheet.
allboolFalseEnable all tools.

Toolkit Functions

FunctionDescription
read_sheetRead values from a Google Sheet. Parameters include spreadsheet_id (Optional[str]) for fallback spreadsheet ID and spreadsheet_range (Optional[str]) for fallback range. Returns JSON of list of rows.
create_sheetCreate a new Google Sheet. Parameters include title (str) for the title of the Google Sheet. Returns the ID of the created Google Sheet.
update_sheetUpdate data in a Google Sheet. Parameters include data (List[List[Any]]) for the data to update, spreadsheet_id (Optional[str]) for the ID of the Google Sheet, and range_name (Optional[str]) for the range to update. Returns success or failure message.
create_duplicate_sheetCreate a duplicate of an existing Google Sheet. Parameters include source_id (str) for the ID of the source spreadsheet, new_title (Optional[str]) for new title, and copy_permissions (bool, default=True) for whether to copy permissions. Returns link to duplicated spreadsheet.

Developer Resources