Google Sheets
Coherent can work with spreadsheets using the following tools:
Tool | Action |
---|---|
GSHEETS_READ | Read data from a Google Sheet |
ROWS_TO_TASKS | Convert rows from a Google Sheet into tasks |
GSHEETS_WRITE | Write data to a specific row in a Google Sheet |
These tools allow Coherent to interact with Google Sheets in various ways, from reading data to creating tasks and updating specific rows.
Column Modifiers
The following keywords can be used in any part of column names, and will modify how coherent handles those columns.
This checks are very flexible. For example all the following column names
would be filled with the conversation url: Conversation URL
, CONVERSATION URL
, CONVERSATION_URL
, conversation url (chat history)
, Chat history (conversation_UrL)
Title
Uses the cell's content as the title of the conversation, in combination with the row number.
# | Account (Title) | ... | Conversation title |
---|---|---|---|
2 | Acme Corp. | ... | 1: Acme Corp. |
3 | Example Inc. | ... | 2: Example Inc. |
4 | Test Company | ... | 3: Test Company |
Ignore
Makes the column invisible to the agents. By default, all columns are visible except the ones autofilled by Coherent.
Cost
Fills the cell with the cost of the conversation in credits.
Conversation URL
Fills the cell with the conversation url.
Message count
Fills the cell with the number of messages in the conversation.
Special Columns
The following columns or column naming conventions have special behaviors.
.* Source
Columns ending with Source
are linked to their corresponding main columns (e.g. Foo Source -> Foo
).
The agent must provide a value for the Source column before filling the Main column.
Any Source column can be filled with the value "linkedin" if the column linkedin is being filled with a url simultaneously. Both case insensitive.
We can generalize this further to all columns, not just "LinkedIn". Please reach out with specific use cases.
Example
# | Foo | Foo Source | Bar | Position | Position Source | |
---|---|---|---|---|---|---|
2 | John | https://example.com/john | 42 | https://linkedin.com/in/john | Software Engineer | LinkedIn ✅ becomes URL |
3 | Alice | ❌ Required if setting Foo | 23 | Software Engineer | Foo ❌ Not url |
Example
#### GSHEETS_WRITE
{
"spreadsheet_id": "1iv51h2vsdb321b52j55l1h",
"sheet": "Sheet1",
"cells": {
"1": {
"Foo": "John",
"Foo Source": "https://example.com/john",
"Bar": "42",
// LinkedIn Alias example
"LinkedIn": "https://linkedin.com/in/john",
"Position": "Software Engineer",
"Position Source": "LinkedIn" // Will become "https://linkedin.com/in/john"
}
}
}
.* (.* /regex/)
This feature allows for validation of column values using regular expressions specified within the column names. It functions similarly to the Instructions section and is a subset of it. The regex is introduced as part of the instructions in the column name.
Examples
-
Country (ISO code, like
/^[A-Z]{2}$/
)- ✅
ES
- ❌
ESP
- ✅
-
Company Size Range (From LinkedIn, like
/^\d+-\d+$/
)- ✅
100-200
- ❌
172
- ✅
-
Potential Client (TRUE / FALSE, like
/^(TRUE|FALSE)$/
)- ✅
TRUE
,FALSE
- ❌
True
,False
- ✅
These regular expressions ensure that when filling a column, the value adheres to the specified format by checking against the regex pattern.
Handling N/A
Values
If the column name mentions N/A
(it must be in uppercase), then the value N/A
is also considered valid in addition to values that match the regex pattern. Other variations like n/a
, NA
, or other capitalizations are not accepted.
The inclusion of N/A
in the column name allows for cases where the data
might not be available or applicable. Ensure that agents are aware that only
N/A
in uppercase is acceptable when the option is provided.
Example with N/A
- Employee Count (like
/^\d+$/
, or N/A)- ✅
150
,N/A
- ❌
n/a
,150+
,NA
- ✅
.* (Instructions)
The content between the parentheses after a column name is used as instructions for Coherent to fill that column.
The conversation variable COLUMN_INSTRUCTIONS
is created when reading a spreadsheet or creating tasks from rows and is passed down to child conversations.
The following column headings in the spreadsheet:
- HubSpot ID (ignore) → Invisible
- Conversation URL → Invisible, automatic hyperlink to the conversation
- LinkedIn (Of the person, not the company!) → Column + Instructions
- Position (Most representative position, just one. e.g. Software Engineer) → Column + Instructions + Source Column
- Position Source → Shown as part of Position row
- Open For Work ( "TRUE" / "FALSE", based on linkedin profile) → Column + Instructions
- Comments → Column
Will result in the following COLUMN_INSTRUCTIONS
:
Column | Instructions | Source Column |
---|---|---|
Of the person, not the company! | ||
Position | Most representative position, just one. e.g. Software Engineer | Position Source |
Open For Work | "TRUE" / "FALSE", based on linkedin profile | |
Comments |
Column Instructions
A transposed table of all the visible columns in the spreadsheet, their instructions, and their Source columns.
Conversation Variable
| Column | Instructions | Source Column |
| ------------- | -------------------------------------------------------------- | --------------- |
| LinkedIn | Of the person, not the company! | |
| Position | Most representative position, just one. e.g. Software Engineer | Position Source |
| Open For Work | "TRUE" / "FALSE", based on linkedin profile | |
Read Sheets
Parameters for the google sheet read request.
Required attributes
- Name
- █
- Name
spreadsheet_id
- Type
- string
- Description
Spreadsheet ID, either provided as input or can be extracted from the URL
Optional attributes
- Name
- █
- Name
sheet
- Type
- string
- Description
The name of the sheet to read/write. Leave empty to use the first sheet.
- Name
- █
- Name
rows
- Type
- array[integer]
- Description
When the user asks for specific rows or rows meeting some condition, instead of using range you can specify the list of rows to read.
- Name
- █
- Name
range
- Type
- string
- Description
If no rows are specified, the range of cells to read in A1 notation. For example, 'A1:Z100' for the first 100 rows, or 'head' to read the first and last rows (if no rows are specified).
A1:ZZ100
Function Call
#### GSHEETS_READ
```json
{
"range": "A1:Z100",
"spreadsheet_id": "1iv51h2vsdb321b52j55l1h"
}
```
Response
#### Success
Convert Rows to Tasks
Parameters for the google sheet read request.
Required attributes
- Name
- █
- Name
spreadsheet_id
- Type
- string
- Description
Spreadsheet ID, either provided as input or can be extracted from the URL
- Name
- █
- Name
team
- Type
- string
- Description
The team to assign the tasks to, with the @ symbol.
@SubordinateTeam
Optional attributes
- Name
- █
- Name
sheet
- Type
- string
- Description
The name of the sheet to read/write. Leave empty to use the first sheet.
- Name
- █
- Name
rows
- Type
- array[integer]
- Description
When the user asks for specific rows or rows meeting some condition, instead of using range you can specify the list of rows to read.
- Name
- █
- Name
range
- Type
- string
- Description
If no rows are specified, the range of cells to read in A1 notation. For example, 'A1:Z100' for the first 100 rows, or 'head' to read the first and last rows (if no rows are specified).
A1:ZZ100
- Name
- █
- Name
headers
- Type
- array[string]
- Description
The columns to use for the tasks. If not provided, all the columns will be used.
- Name
- █
- Name
message_sender
- Type
- string
- Description
The handle of the agent that will send the message. Should be a member of the team running the tasks.
If not specified, the default agent in the team (PLANNER) will send the message.
@Manager
- Name
- █
- Name
message_content
- Type
- string
- Description
The description of the task. Always end mentioning this two variables in this way:
{{ROW}}: {{ROW_PREVIEW}}
Process row {{ROW}}: \n\n{{ROW_PREVIEW}}
- Name
- █
- Name
max_autoreply
- Type
- integer
- Description
The maximum number of replies to generate before stopping and waiting for user input.
2
- Name
- █
- Name
sleep_between_tasks
- Type
- integer
- Description
The number of seconds to sleep between creating each task.
1
Function Call
#### ROWS_TO_TASKS
```json
{
"rows": [
2,
3,
7,
11
],
"spreadsheet_id": "1iv51h2vsdb321b52j55l1h",
"team": "@SubordinateTeam"
}
```
Response
#### Success
Row Preview
Passed down to children conversations as working memory for the row they are working on. Gets updated as mutations are performed on the row.
Conversation Variable
| Row | Name | Age | Email |
| --- | --- | --- | --- |
| 1 | John Doe | 30 | john@example.com |
| 2 | Jane Smith | 28 | jane@example.com |
Conversation Variable
2
Conversation Variable
1iv51h2vsdb321b52j55l1h
Conversation Variable
Sheet1
Other Columns
Any columns from the spreadsheet get passed down as variables, for example
Active Users (#, do not include admin)
becomes the variable ACTIVE_USERS
after stripping the instructions and converting to variable format.
Conversation Variable
42
Write Row to Sheet
Required attributes
- Name
- █
- Name
spreadsheet_id
- Type
- string
- Description
Spreadsheet ID, either provided as input or can be extracted from the URL
- Name
- █
- Name
cells
- Type
- object
- Description
A dictionary where keys are row numbers and values are dictionaries mapping column headers to cell values.
Optional attributes
- Name
- █
- Name
sheet
- Type
- string
- Description
The name of the sheet to read/write. Leave empty to use the first sheet.
Function Call
#### GSHEETS_WRITE
```json
{
"cells": {
"5": {
"Age": "30",
"Name": "John Doe"
}
},
"spreadsheet_id": "1iv51h2vsdb321b52j55l1h"
}
```
Response
#### Success