Python API
Smartsheet
- class RPA.Smartsheet.Smartsheet(access_token: str | None = None, max_retry_time: str | int = 30)
Smartsheet is a library for accessing Smartsheet using the Smartsheet API 2.0. It extends smartsheet-python-sdk.
Getting started
To use this library, you need to have a Smartsheet account and an API token. You can get your API token from the Smartsheet Developer Portal. This library currently only supports raw token authentication. Once obtained, you can configure the access token using the
Set Access Token
keyword or via theaccess_token
argument in the library import.Working on a sheet
The library supports working on a single sheet at a time. To select a sheet to work on, use the
Select Sheet
keyword. This will set the sheet as the active sheet for all subsequent operations. Some operations update the sheet, but this will not necessarily be reflected in the active sheet. To refresh the active sheet, use theRefresh Sheet
keyword.Native Smartsheet objects
You can retrieve the native Smartsheet object from many keywords by specifying the
native
argument. The default will return a more common Python object, such as a dictionary or list. The native object is a class from the smartsheet-python-sdk library and will have additional methods and attributes. The most important attributes available for most native objects are (some may be unavailable for some objects):id
: the unique identifier of the objectname
: the name of the objecttitle
: the title of a columnpermalink
: the URL to the object
- ROBOT_AUTO_KEYWORDS = False
- ROBOT_LIBRARY_DOC_FORMAT = 'REST'
- ROBOT_LIBRARY_SCOPE = 'GLOBAL'
- ROW_EXCLUDES = ['filteredOutRows', 'linkInFromCellDetails', 'linksOutToCellsDetails', 'nonexistentCells']
List of supported options to remove cells from rows.
- ROW_INCLUDES = {'attachmentFiles': None, 'attachments': 'attachments', 'discussions': 'discussions', 'filters': 'filteredOut', 'rowId': None, 'rowPermalink': 'permalink'}
Dictionary of supported additional objects to ask for via
include
parameters for rows. Key is the name of the option, value is the API attribute or function to call.
- SEARCH_INCLUDES = {'favoriteFlag': None}
Dictionary of supported additional objects to ask for via
include
parameters for searches. Key is the name of the option, value is the API attribute or function to call.
- SEARCH_SCOPES = ['attachments', 'cellData', 'comments', 'folderNames', 'reportNames', 'sheetNames', 'sightNames', 'summaryFields', 'templateNames', 'workspaceNames']
- SHEET_INCLUDES = {'attachmentFiles': None, 'attachments': 'attachments', 'discussions': 'discussions', 'rowId': None, 'rowPermalink': 'permalink'}
Dictionary of supported additional objects to ask for via
include
parameters for sheets. Key is the name of the option, value is the API attribute or function to call.
- add_column(title: str, column_type: str = 'TEXT_NUMBER', formula: str | None = None, hidden: bool = False, index: int | None = None, description: str | None = None, primary: bool = False, format_string: str | None = None, locked: bool = False, options: List[str] | None = None, symbol: str | None = None, validation: bool = False, width: int | None = None)
Adds a column to the current sheet.
- Parameters:
title – Column title.
column_type – Column type, must be a supported type. Defaults to
TEXT_NUMBER
.formula – Formula for the column (e.g.,
=data@row
). Defaults toNone
.hidden – Whether the column is hidden. Defaults to
False
.index – Index of the column. You can insert a column into and existing sheet by setting this index. Index is zero-based. Defaults to
None
which will add the column to the end of the sheet.description – Column description. Defaults to
None
.primary – Whether the column is considered the primary key for indexing and searching. Defaults to
False
.format_string – Column format using a format descriptor string. Defaults to
None
.locked – Whether the column is locked. Defaults to
False
.options – List of options for a
PICKLIST
orMULTI_PICKLIST
column. Defaults toNone
.symbol – When a
CHECKBOX
orPICKLIST
column has a display symbol, you can set the type of symbols by selected an appropriate string from the symbol columns definitions. Defaults toNone
.validation – Whether validation has been enabled. Defaults to
False
.width – Column width in pixels. Defaults to
None
.
Example:
Add Column Title TEXT_NUMBER Add Column Description TEXT_NUMBER description=This is a description Add Column Formula TEXT_NUMBER formula==data@row
ss = Smartsheet(access_token=access_token) ss.add_column(title="Title", column_type="TEXT_NUMBER") ss.add_column(title="Description", column_type="TEXT_NUMBER", description="This is a description") ss.add_column(title="Formula", column_type="TEXT_NUMBER", formula="=data@row")
- add_columns(columns: List[Dict | Column] | None = None) List[Column]
Adds columns to the current sheet. Columns must be defined as a list of dictionaries or Column objects. Dictionaries can have additional keys set, see
Add Column
keyword for more information.Column types must be supported by the Smartsheet API
- Parameters:
columns – Columns as a list of dictionaries or Column objects.
- add_rows(data: List | Table, native: bool = False) List[OrderedDict | Row]
Adds rows to the current sheet with the provided data.
You can provide the data in several ways:
As a list of dictionaries: each list item represents a row as a single dictionary. The keys of the dictionary are the column IDs or Titles and the values are the values for the cells.
As a list of lists of dictionaries: each sub list item is a row and each dictionary is a cell. The keys of the dictionary should match cell attributes, e.g.,
column_id
,title
,value
, etc. See the `smartsheet API docs`_ for more information. The dictionary keys must be provided in snake case. You must use this method to set formulas on the row.As a list of native
Row
objects: eachRow
object is a native object from the API with new values for the cells.As a
Table
object: the columns of the Table must either be the column IDs or Titles.
Examples:
Robot Framework:
${row1}= Create Dictionary column1=value1 column2=value2 ${row2}= Create Dictionary column1=value3 column2=value4 ${row3}= Create Dictionary column1=value5 column2=value6 ${data} = Create List ${row1} ${row2} ${row3} Add Rows ${data}
Python:
ss = Smartsheet(access_token=access_token) row1 = {"column1": "value1", "column2": "value2"} row2 = {"column1": "value3", "column2": "value4"} row3 = {"column1": "value5", "column2": "value6"} data = [row1, row2, row3] ss.set_rows(data)
- convert_row_to_dict(row: Row) OrderedDict
Converts a row object to a dictionary.
- convert_sheet_to_table(sheet: Sheet | None = None) Table
Converts the current sheet to table. You can provide a differnt native sheet object to be converted via the
sheet
parameter.This keyword attempts to return the sheet as a table via
RPA.Tables
, but if that library is not available in this context, the sheet is returned as its native data model (e.g., no operation is performed).If the sheet contains additional data from the
include
argument, they will be appended to the end of the table as additional columns in the data model. These additional objects will be attached as a list of objects depending on the items requested.
- create_sheet(name: str, columns: List[Dict | Column] | None = None, from_sheet_id: str | int | None = None) Sheet
Creates a new sheet with the given name and columns, then sets the current sheet to the new sheet and returns it as a native Smartsheet object.
- Parameters:
name – Name of the new sheet.
columns – List of columns to create in the new sheet.
from_sheet_id – Sheet ID to use as a template for the new sheet.
Example:
${columns}= Create List Name Email ${sheet}= Create Sheet My new sheet ${columns}
ss = Smartsheet(access_token=access_token) columns = [ {"title": "Name", "type": "TEXT_NUMBER"}, {"title": "Email", "type": "TEXT_NUMBER"}, ] sheet = ss.create_sheet("My new sheet", columns)
- download_attachment(attachment: int | str | Dict | Attachment, download_path: str | Path | None = None) Path
Downloads the provided attachment from the currently selected sheet to the provided download_path, which defaults to the
${OUTPUT_DIR}
.The attachment can be provided as an integer representing the attachments ID, a dictionary with at least the key
id
or as the nativeAttachment
data model type.- Parameters:
attachment – An integar representing the attachment ID, a dictionary with at least the key
id
, or a nativeAttachment
data model object.download_path – The path to save the attachment to.
Examples:
Robot Framework:
${attachment}= Get Attachment 123456789 ${path}= Download Attachment ${attachment} Log ${path}
Python:
ss = Smartsheet(access_token=access_token) attachment = ss.get_attachment(123456789) path = ss.download_attachment(attachment) print(path)
- get_application_constants() ServerInfo
Gets application constants from the server. This is not necessary for most automation scenarios, but may be useful for debugging or for other advanced scenarios.
- get_cell_history(row: int | Row, column: int | str | Column) List[Cell] | None
Retrieves the history of a cell in a row of the current sheet.
- Parameters:
row – The row ID, row number, or a Row object.
column – The column ID or title.
Examples:
Robot Framework:
${cell_history}= Get Cell History 1 Approval FOR ${revision} IN @{cell_history} Log Modified by ${revision.modified_by.email} END
Python:
ss = Smartsheet(access_token=access_token) cell_history = ss.get_cell_history(1, "Approval") for revision in cell_history: print(f"Modified by {revision.modified_by.email}")
- get_current_user() User
Gets the current authenticated user, which is also set in the library’s memory as the current user. Call this again if you switch user or begin to impersonate a user.
- get_row(row: int | Row, include: str | List[Any] | None = None, exclude: str | List[Any] | None = None, native: bool = False) Row | OrderedDict
Returns a single row from the current sheet.
You can provide the row as a native
Row
object or as an integer representing the row ID.
- get_sheet(sheet_id: int | None = None, sheet_name: str | None = None, include: str | List[Any] | None = None, row_ids: str | List[Any] | None = None, row_numbers: str | List[Any] | None = None, column_ids: str | List[Any] | None = None, filter_id: int | None = None, native: bool = False, download_path: str | Path | None = None) Table | Sheet
Retrieves a sheet from Smartsheet. This keyword also sets the currently selected sheet to the returned sheet.
You cannot provide both a
sheet_id
andsheet_name
.- Parameters:
sheet_id – The ID of the sheet to get. You cannot supply both a
sheet_id
andsheet_name
.sheet_name – The name of the sheet to get, it will return the first sheet name matching the provided name. You cannot supply both a
sheet_id
andsheet_name
.include – Additional metadata which can be retrieved with the table. The list can only contain the following items:
attachments
,attachmentFiles
,discussions
,rowPermalink
, orALL
. Note thatattachmentFiles
will only download files if you do not setnative
toTrue
.row_ids – A list of row IDs to include. All other rows will be ignored. The list can be a list object or a comma-separated list as a string.
row_numbers – A list of row numbers to include. All other rows will be ignored. The list can be a list object or a comma-separated list as a string.
column_ids – A list of column IDs to only include, others will not be returned. The list can be a list object or a comma-separated list as a string.
filter_id – The ID of a filter to apply. Filtered out rows will not be included in the resulting table.
native – Defaults to
False
. Set toTrue
to change the return type to the native Smartsheet data model. The native type is useful for passing to other keywords as arguments.download_path – Defaults to
None
. Can be set whenattachmentFiles
is included in theinclude
parameter. All attachments will be downloaded to the provided directory.
Example:
${sheet}= Get Sheet sheet_name=My Sheet FOR ${row} IN &{sheet} FOR ${column} ${value} IN &{row} Log The column ${column} has the value ${value} END END
ss = Smartsheet(access_token=access_token) sheet = ss.get_sheet(sheet_name="My Sheet", native=True) for row in sheet: for cell in row: print(f"The column {cell.column_id} has the value {cell.value}")
- get_sheet_owner(sheet_id: int | None = None, sheet_name: str | None = None) Tuple[str, int]
Returns the owner’s username and ID for the current sheet.
- list_attachments() List[Attachment] | None
Gets a list of all attachments from the currently selected sheet.
This will include attachments to the sheet, rows, and discussions.
Examples:
Robot Framework:
${attachments}= List Attachments FOR ${attachment} IN @{attachments} Log ${attachment.name} END
Python:
ss = Smartsheet(access_token=access_token) attachments = ss.list_attachments() for attachment in attachments: print(attachment.name)
- list_columns(sheet_id: int | None = None, sheet_name: str | None = None) List[Column] | None
Returns a list of columns for the current sheet.
- Parameters:
sheet_id – The ID of the sheet to get columns from.
sheet_name – The name of the sheet to get columns from.
- list_sheet_filters(sheet_id: int | None = None, sheet_name: str | None = None) List[SheetFilter] | None
Returns a list of available filters for the current sheet. You can specify a different sheet via the
sheet_id
orsheet_name
parameters.The returned list of filters can be used with the
filter_id
argument of theget_sheet
keyword.Example:
${filters}= List Sheet Filters FOR ${filter} IN @{filters} ${filtered_sheet}= Get Sheet ... sheet_name=My sheet ... filter_id=${filter.id} Log There are ${len(filtered_sheet)} rows in the filtered sheet END
ss = Smartsheet(access_token=access_token) my_sheet_id = 123456789 filters = ss.list_sheet_filters() for filter in filters: filtered_sheet = ss.get_sheet( sheet_id=my_sheet_id, filter_id=filter.id, native=True, ) print( f"There are {len(filtered_sheet.rows)} rows in the " f"filtered sheet" )
- list_sheets(use_cache: bool = True) List[Sheet]
Lists all sheets available for the authenticated account. Uses cached lists if available unless
use_cache
is set toFalse
.The cached lists is used for other keywords, so if you need to refresh the cache for other keywords to use, you must do so via this keyword.
- Parameters:
use_cache – Defaults to
True
. You can set toFalse
to force a reload of the cached list of sheets.
Example:
${sheets}= List Sheets FOR ${sheet} IN @{sheets} Log ${sheet.name}
ss = SmartsheetLibrary(account_token=account_token) sheets = ss.list_sheets() for sheet in sheets: print(sheet.name)
- refresh_sheet(native: bool = False) Table | Sheet
Refreshes the current sheet from the API and returns it either as a Table or native data model depending on the
native
argument.
- search(query: str, location: str | None = None, modified_since: str | int | None = None, include: str | List[Any] | None = None, scopes: str | List[Any] | None = None) List[Sheet]
Searches for all sheets for text matching the query. Returns a list of native Smartsheet Sheet objects. You can use the additional parameters to filter the search and increase speed.
- Parameters:
query – The text to search for.
location – The location to search. When specified with a value of
personalWorkspace
, the search will be limited to the current user’s personal workspace.modified_since – The date to search from. This can be either a string or an integer. If an integer is provided, it will be interpreted as a Unix timestamp. If a string is provided, it will be parsed via the Robot Framework time utilities, so you can provided it using keywords like
NOW - 1 day
.include – When specified with the value of
favoriteFlag
, results will either include afavorite
attribute orparentObjectFavorite
attribute depending on the type of object found by the search engine.scopes –
If search fails, try using an array for each type of this comma-separated list of search filters. The following strings can be used to filter the search results:
attachments
: Search in attachments.cellData
: Search in cell data.comments
: Search in comments.folderNames
: Search in folder names.reportNames
: Search in report names.sheetNames
: Search in sheet names.sightNames
: Search in sight names.summaryFields
: Search in summary fields.templateNames
: Search in template names.workspaceNames
: Search in workspace names.
Example:
${sheets}= Search my search query FOR ${sheet} IN @{sheets} Log ${sheet.name}
ss = Smartsheet(access_token=access_token) sheets = ss.search("my search query") for sheet in sheets: print(sheet.name)
- set_access_token(access_token: str) None
Sets the access token to be used when accessing the Smartsheet API.
Learn more about authenticating to Smartsheets here.
- Parameters:
access_token – The access token created for your Smartsheet user.
Example:
Set Access Token ${access_token}
smartsheet = Smartsheet(access_token=access_token) # or smartsheet.set_access_token(access_token)
- set_max_retry_time(max_retry_time: str | int) int | None
Sets the max retry time to use when sending requests to the Smartsheet API. Returns the current max retry time.
- Parameters:
max_retry_time – Maximum time to allow retries of API calls. Can be provided as a time string or int.
- set_row(row: int | Row, data: Dict | List[Dict] | Row | None = None, native: bool = False) Dict | Row
Updates a single row of the current sheet with the provided data.
You can provide the row as a native
Row
object or as an integer representing the row ID. You may omit thedata
argument if you are providing a nativeRow
object.You can provide the data in several ways:
As a dictionary: the keys of the dictionary are the column IDs or Titles and the values are the values for the cells.
As a list of dictionaries: each dictionary is a cell. The keys of the dictionary should match cell attributes, e.g.,
column_id
,title
,value
, etc. See the `smartsheet API docs`_ for more information. The dictionary keys must be provided in snake case. You must use this method to set formulas on the row.As a native
Row
object: a native object from the API with new values for the cells.
For examples, see
Set Rows
.
- set_rows(data: List | Table, native: bool = False) List[OrderedDict | Row]
Updates rows of the current sheet with the provided data.
Note
In order to update rows, you must identify the rows to the API. You can do this by providing the
rowId
orrowNumber
as a column in the data. The ID must be the API ID, while the number is the row number per the UI. This can only be excluded if the length of the data matches the length of the sheet.You can provide the data in several ways:
As a list of dictionaries: each list item represents a row as a single dictionary. The keys of the dictionary are the column IDs or Titles and the values are the values for the cells.
As a list of lists of dictionaries: each sub list item is a row and each dictionary is a cell. The keys of the dictionary should match cell attributes, e.g.,
column_id
,title
,value
, etc. See the `smartsheet API docs`_ for more information. The dictionary keys must be provided in snake case. You must use this method to set formulas on the row.As a list of native
Row
objects: eachRow
object is a native object from the API with new values for the cells.As a
Table
object: the columns of the Table must either be the column IDs or Titles.
Examples:
Robot Framework:
${row1}= Create Dictionary rowId=123 column1=value1 column2=value2 ${row2}= Create Dictionary rowId=456 column1=value3 column2=value4 ${row3}= Create Dictionary rowId=789 column1=value5 column2=value6 ${data} = Create List ${row1} ${row2} ${row3} Set Rows ${data} # Or work with native row objects to update them. ${row1}= Get Row 123 FOR ${cell} IN @{row1.cells} IF ${cell.column_id} == 123 ${cell.value}= Set Variable New Value END END ${data}= Create List ${row1} Set Rows ${data}
Python:
ss = Smartsheet(access_token=access_token) row1 = {"rowId": 123, "column1": "value1", "column2": "value2"} row2 = {"rowId": 456, "column1": "value3", "column2": "value4"} row3 = {"rowId": 789, "column1": "value5", "column2": "value6"} data = [row1, row2, row3] ss.set_rows(data) # or work with native row objects to update them. row1 = ss.get_row(123) for cell in row1.cells: if cell.column_id == 123: cell.value = "New Value" data = [row1] ss.set_rows(data)
- property sheets: List[Sheet]
Full list of cached sheets.
- unselect_current_sheet() None
Resets the current sheet to None.
- update_column(column: int | str | Column, **kwargs) Column
Updates a column in the current sheet. See the
Add Column
keyword for a list of supported attributes.- Parameters:
column – Column ID or title.
kwargs – Column attributes to update. See
Add Column
keyword for a list of supported attributes.