Tables
Studio Pro activities > Spreadsheets > Tables. Includes "Read table", "For each row", "Remove empty rows" and "Save table".
Activities
Read table | For each row |
---|---|
Read the contents of a specified table | Apply a set of actions to each row in the specified table |
Remove empty rows | Save table |
Removes all empty rows from a table | Save the table in Excel, Google Sheets or CSV format |
Read table
Description
This activity is used to read the contents of a specified table. Excel, Google Sheets and CSV tables are supported.
When adding this activity to a workflow, an 'Assign value to variable' action block connected to this block will also appear. The result of reading operation will be saved to this variable. That being said, this variable stores the table contents and provides a visual representation of the table data.
However, using the 'Assign value to variable' activity is not strictly necessary in this case. It is safe to delete this block and handle the result any other way. For example, it is possible to connect the 'Read table' activity to the 'For each row' activity and use the Save the previous step result option.
One more important thing to remember: in case your table is currently open in any desktop application, do not forget to close it. Otherwise, Studio will not be able to get access to the file and execute the activity.
Parameters
The set of parameters depends on the chosen option: Excel, Google Sheets or CSV.
Read table from is the general parameter which defines what kind of table you are going to read. It is required.
data:image/s3,"s3://crabby-images/95630/95630d732a9f28a2c09ed71f928ba1063b5e9cbe" alt="The Read table from parameter and the available options"
The Read table from parameter and the available options
Excel
Reading an Excel table works the same way as the separate 'Read Excel table' activity. Read about it in this article Read Excel file.
Google Sheets
If we choose to read a table from Google Sheets, we will see the following parameters.
The first one here is Google account. It is required to connect the account where the table is stored. If you have not done this yet, this is what you will see here.
data:image/s3,"s3://crabby-images/f819f/f819f5c7f87a363b69f3b981496d33f793a9d12e" alt="This message shows that the Google account is not connected"
This message shows that the Google account is not connected
Click the link in this message. The settings menu will open. Here you will be able to login to your Google account and connect it. Click the Authenticate button to do it.
data:image/s3,"s3://crabby-images/d5640/d56409bfb787196c16da25249d9560af844f8d9b" alt="The **Services** menu where you can login to your account"
The Services menu where you can login to your account
Once it is done, you should see this message. It indicates that you can use the table stored in your account.
data:image/s3,"s3://crabby-images/6b2bc/6b2bc2d137c75f5130c3c7b38b476b4ea221d209" alt="This message shows that your Google account is connected"
This message shows that your Google account is connected
The next parameter is Spreadsheet Id. It is used to specify the table itself. Pay attention to the tooltip that appears when hovering your cursor over the input field: it is only required to input the ID of the table, not the whole link. This is a requiredparameter.
For example, if the link is <https://docs.google.com/spreadsheets/d/11sw2l2a6b1n2l8aDP_E9_SjAV/edit#gid=0>
, then the ID is 11sw2l2a6b1n2l8aDP_E9_SjAV
.
data:image/s3,"s3://crabby-images/dcc86/dcc86e9393981874e880f05ec6b69bad715ac8ce" alt="Spreadsheet Id parameter"
Spreadsheet Id parameter
data:image/s3,"s3://crabby-images/87327/87327ecfd0e3f76ec17bc2a8e6399636305a3f2d" alt="Tooltip showing how to input the table ID"
Tooltip showing how to input the table ID
The last parameter is Range. It defines what part of the table needs to be read. There is also a tooltip for it. This is a required parameter.
data:image/s3,"s3://crabby-images/5dfae/5dfaebe2a4bc025b3a38f704eed3544ede56fcb7" alt="Range parameter and the tooltip"
Range parameter and the tooltip
CSV
The only parameter here is Path which lets you specify the needed .csv table file. Use the 'Pick' option to choose the file using Explorer. This is a required parameter.
Studio Pro supports auto recognition of such delimiters as ,, ; and tab. Regardless of the chosen delimiter, the data from the table will be read in the exact same way.
data:image/s3,"s3://crabby-images/a8d52/a8d52245fa912d096664ff73b953664dd4c1e2c2" alt="Path parameter"
Path parameter
Results
In this case we used the 'Assign value to variable' activity to save and display the results.
Excel
The representation of Excel tables data is described here. Read Excel file
Google Sheets
data:image/s3,"s3://crabby-images/3c700/3c700a67b4fd1fcf902d0ab56bb95cbdbf39dc88" alt="An example of a read Google Sheets table"
An example of a read Google Sheets table
CSV
data:image/s3,"s3://crabby-images/832e2/832e21a7dda2e407d0abd58f7317a6f4b49c55b9" alt="An example of a read CSV table"
An example of a read CSV table
For each row
Description
This activity makes it possible to apply a set of actions to each row in the specified table.
It has a special structure. When added to a workflow, a gray region will appear. It contains the body of the loop (i.e. the set of actions you are going to perform). Drag and drop the desired activities here and connect them with the activity block itself and the 'Loop end' block.
This is how a newly added block looks like.
data:image/s3,"s3://crabby-images/23526/2352600c48a80509de8aee5a0bd9d64daad643a5" alt="A template of the 'For each row' activity"
A template of the 'For each row' activity
Example
Let us start with an example of a workflow that has this activity. Here we read the contents of the table, save it to a variable and output the contents by each column to the console.
data:image/s3,"s3://crabby-images/0db47/0db472b48abedd8cb58c7b64c299717705096c7c" alt="An example of a workflow with this activity"
An example of a workflow with this activity
data:image/s3,"s3://crabby-images/9d142/9d14241b6fc36f171fa88bd9f3c9ab52d7f1ad58" alt="The contents of the source table"
The contents of the source table
These 'Console log' blocks are responsible for displaying the output. Each block displays one column of the table. Here is an example of how they are set.
data:image/s3,"s3://crabby-images/66ca8/66ca87b39be75f3398bc30b1f498a45dc735551b" alt="This 'Console log' block outputs the contents of the 'Name' column. Others display 'Surname' and 'Age' columns and are set similarly"
This 'Console log' block outputs the contents of the 'Name' column. Others display 'Surname' and 'Age' columns and are set similarly
data:image/s3,"s3://crabby-images/85f07/85f07f821d34e1737207be17412d0b2faca0eb58" alt="As a result the contents are displayed by each column"
As a result the contents are displayed by each column
Parameters
Now let us review the parameters of the activity based on the shown example.
Table parameter defines the source table itself. imported_table is the name of the table that we have read.
It is worth mentioning that this activity is best to use in conjunction with 'Read table'. In that case, if 'For each row' is placed right after 'Read table', then you do not need to save the table content to a variable and you can leave the Save the previous step option enabled.
data:image/s3,"s3://crabby-images/a8ac2/a8ac2f9b013079ac1c15331755869bf401e6e9fe" alt="Table parameter"
Table parameter
Template table defines the table (an .xls or .xlsx file) that will be used as a template to automatically generate the column variables. It is possible to either pick the same table you have already read or create a separate one. This is done to just generate the variable names for the columns.
data:image/s3,"s3://crabby-images/5eebe/5eebe5851e97175c227ca70c38e544932684e006" alt="Template table parameter"
Template table parameter
This is how the template table looks in our case.
data:image/s3,"s3://crabby-images/11095/110959e10fb045ad8a70c5c401baae5b885850b3" alt="The template table only contains the column names"
The template table only contains the column names
Variables parameter defines what will be used for the names of the column variables: table headers as specified in the template table or plain letters.
data:image/s3,"s3://crabby-images/54fc7/54fc7a1d742516256b30aed93e514d17f15a7c83" alt="Variables parameter"
Variables parameter
Here we can view them. Column header and column name are the same because we have chosen the Use table headers option. The variable names are editable.
data:image/s3,"s3://crabby-images/df62f/df62fbc617447e3f8be6965e1b47b8abb27b256c" alt="Click the 'Show' button to see the details"
Click the 'Show' button to see the details
If the Use column letters option is selected, then the Name, Surname and Age headers will be replaced with A, B and C respectively.
Results
Here is the output we have received. Each 'Console log' block displays one column (name, surname and age variables).
data:image/s3,"s3://crabby-images/5f9b6/5f9b641fb015efd82dff75d003543544c5a7f8b2" alt="The table contents displayed in the console log"
The table contents displayed in the console log
Remove empty rows
Description
Removes all empty rows from a table.
Parameters
Table
- Save the previous step result: take the previous step result to get a variable that contains a table.
- Calculate a value: use JS to get a table.
Condition
- Each cell in a row is empty: removes all rows with all empty cells.
- At least one cell in a row is empty: removes all rows with at least one empty cell.
Usage Examples
This activity helps to filter your table and remove all empty rows.
Save table
Description
This activity saves the table in Excel, Google Sheets or CSV format.
A possible usage example is to read a table and save its contents into a different table. This is what this workflow does. Save the previous step result option is used.
data:image/s3,"s3://crabby-images/fa7bf/fa7bf18cde249d2723f204fe550a2ddbf8fb8970" alt="This bot reads the table and saves the contents to another table"
This bot reads the table and saves the contents to another table
Parameters
The first parameter is Table. It is required. The table you are going to save is specified here. Note that it does not have Set a value option - it is intended for use either with Calculate a value option where you set the table dynamically or Save the previous step result option which is the most convenient for use with variables.
data:image/s3,"s3://crabby-images/8cb85/8cb8562d51606a4fee3baea25cc63e9d859b8766" alt="Table parameter"
Table parameter
The Calculate a value option lets you form the value dynamically. Here is a usage example:
{
"My List": [
{
"Country": "Russia",
"Capital": "Moscow"
},
{
"Country": "USA",
"Capital": "Washington DC"
}
]
}
"My List" is the table sheet name, "Country" and "Capital" are columns, "Russia", "USA", "Moscow" and "Washington DC" are the respective values that will be written to the columns.
data:image/s3,"s3://crabby-images/ebafd/ebafd3e0624f7c9be341b704d06ee0c5116e37ca" alt="An example of setting up the value using the Calculate a value option"
An example of setting up the value using the Calculate a value option
This is how the result would look like.
data:image/s3,"s3://crabby-images/92baa/92baab1ae8a511d4b01ec67a9e5cdf7514f3c0a7" alt="The new data was written to the Excel file"
The new data was written to the Excel file
The next parameter is Save table as. It is required. Here you can choose Excel, Google Sheets or CSV format. Each format has a different set of options.
This is a set of options for Excel format. It is also possible to select a specific table sheet.
data:image/s3,"s3://crabby-images/7cf65/7cf6575c1bd409375f6f7fd70cb7dac27293c433" alt="Options for Excel format"
Options for Excel format
Options for Google Sheets are different. Also do not forget that it requires a connected Google account. It can be added in 'Settings' - 'Services Connection' menu.
data:image/s3,"s3://crabby-images/13045/13045a8fdc545b0e9615070d8ea436d5f6c5a0a5" alt="Options for Google Sheets"
Options for Google Sheets
And here are the options for CSV format. Its unique feature is Delimiter. Commas, semicolons or tabs can be used.
data:image/s3,"s3://crabby-images/582b1/582b174a04e931bba0ae3627c7d117fd67866e21" alt="Options for CSV format"
Options for CSV format
Updated over 1 year ago