Develop and run code in Snowflake Notebooks¶
This topic describes how to write and run code in Snowflake Notebooks.
Notebook cell basics¶
This section introduces some basic cell operations. When you create a notebook, three example cells are displayed. You can modify those cells or add new ones.
Create a new cell¶
Snowflake Notebooks support three types of cells: SQL, Python, and Markdown. To create a new cell, you can either hover over an existing cell or scroll to the bottom of the notebook, then select one of the buttons for the cell type you want to add.
You can change the language of the cell any time after it’s created by using one of two methods:
Select the language dropdown menu and then select a different language.
Move cells¶
You can move a cell either by dragging and dropping the cell using your mouse or using the actions menu:
(Option 1) Hover your mouse over the existing cell you want to move. Select the drag and drop icon with your mouse and move the cell to its new location.
(Option 2) Select the vertical ellipsis (actions) menu. Then select the appropriate action.
Note
To just move the focus between cells, use the Up and Down arrows.
Delete a cell¶
To delete a cell, complete the following steps in a notebook:
You can use a keyboard shortcut to delete a cell as well.
For considerations when using Python and SQL cells, see Considerations for running notebooks.
Run Python and SQL cells in Snowflake Notebooks¶
To run Python and SQL cells in Snowflake Notebooks, you can:
Run a single cell: Choose this option when making frequent code updates.
Run all cells in a notebook in sequential order: Choose this option before presenting or sharing a notebook to ensure that the recipients see the most current information.
Press CMD + Shift + Return on a Mac keyboard, or CTRL + Shift + Enter on a Windows keyboard.
Select Run all.
Run a cell and advance to the next cell: Choose this option to run a cell and move on to the next cell more quickly.
Press Shift + Return on a Mac keyboard, or Shift + Enter on a Windows keyboard.
Select the vertical ellipsis (more actions) for a cell, and choose Run cell and advance.
Run all above: Choose this option when running a cell that references the results of earlier cells.
Select the vertical ellipsis (more actions) for a cell, and choose Run all above.
Run all below: Choose this option when running a cell that later cells depend on. This option runs the current cell and all following cells.
Select the vertical ellipsis (more actions) for a cell, and choose Run all below.
When one cell is running, other run requests are queued and will be executed once the actively running cell finishes.
Inspect cell status¶
The status of the cell run is indicated by the colors displayed by the cell. This status color is displayed in two places, the left wall of the cell and in the right cell navigation map.
Cell status color:
Blue dot - Indicates a cell has been modified but hasn’t run yet.
Red - An error has occurred.
Green - Run was successful.
Moving green - The cell is currently running.
Blinking gray - The cell is waiting to be run. This status occurs when multiple cells are triggered to run.
Note
Markdown cells do not show any status.
After a cell finishes running, the time it took to run is displayed at the top of the cell. Select this text to see the run details window. You can view the run details, including execution start and end times and total elapsed time.
SQL cells contain additional information, such as the warehouse used to run the query, rows returned, and a hyperlink to the query ID page.
Stop a running cell¶
To stop the execution of any code cells that are currently running, select the stop button on the top right of the cell.
This will stop the execution of the cell that is currently running and all subsequent cells that have been scheduled to run.
Format text with Markdown¶
To include Markdown in your notebook, add a Markdown cell:
Use a keyboard shortcut and select Markdown, or select + Markdown.
Select the Edit markdown pencil icon or double click on the cell, and start writing Markdown.
You can type valid Markdown to format a text cell. As you type, the formatted text appears below the Markdown syntax.
To view only the formatted text, select the Done editing checkmark icon.
Note
Markdown cells currently do not support rendering of HTML.
Markdown basics¶
This section describes basic Markdown syntax to get you started.
Headers
Heading level |
Markdown syntax |
Example |
---|---|---|
Top level |
# Top-level Header
|
|
2nd-level |
## 2nd-level Header
|
|
3rd-level |
### 3rd-level Header
|
Inline text formatting
Text format |
Markdown syntax |
Example |
---|---|---|
Italicize |
*italicized text*
|
|
Bold |
**bolded text**
|
|
Link |
[Link text](url)
|
Lists
List type |
Markdown syntax |
Example |
---|---|---|
Ordered list |
1. first item
2. second item
1. Nested first
2. Nested second
|
|
Unordered list |
- first item
- second item
- Nested first
- Nested second
|
Code formatting
Language |
Markdown syntax |
Example |
---|---|---|
Python |
```python
import pandas as pd
df = pd.DataFrame([1,2,3])
```
|
|
SQL |
```sql
SELECT * FROM MYTABLE
```
|
Embed images
File type |
Markdown syntax |
Example |
---|---|---|
Image |
![<alt_text>](<path_to_image>)
|
For a notebook that demonstrates these Markdown examples, see the Markdown cells section of the visual data stories notebook.
Understanding cell outputs¶
When you run a Python cell, the following types of output from the cell are displayed in the results:
Any results written to the console, such as print(), logs, errors and warnings.
Dataframes are automatically printed with Streamlit’s interactive table display,
st.dataframe()
.The dataframe display types currently supported include pandas dataframe, Snowpark dataframes, and Snowpark Tables.
For Snowpark, printed dataframes are evaluated eagerly without the need to call
.show()
. If you prefer not to evaluate the dataframe eagerly, for example when running the notebook in non-interactive mode, Snowflake recommends removing the dataframe print statements to speed up the overall runtime of your Snowpark code.
Visualizations are rendered in outputs. To learn more about visualizing your data in Snowflake Notebooks, see Visualize data in Snowflake Notebooks.
Additionally, you can access the results of your SQL query in Python and vice versa. See Reference cells and variables in Snowflake Notebooks.
Reference cells and variables in Snowflake Notebooks¶
You can reference the results of previous cells in a cell in your notebook. For example, if you want to reference the result of a SQL cell or the value of a Python variable, refer to the following tables.
Note
The cell name of the reference is case-sensitive and must exactly match the name of the referenced cell.
Referencing SQL output in Python cells:
Reference cell type |
Current cell type |
Reference syntax |
Example |
---|---|---|---|
SQL |
Python |
|
Convert the SQL table of results to a Snowpark dataframe. If you have the following in a SQL cell called SELECT 'FRIDAY' as SNOWDAY, 0.2 as CHANCE_OF_SNOW
UNION ALL
SELECT 'SATURDAY',0.5
UNION ALL
SELECT 'SUNDAY', 0.9;
You can reference the cell to access the SQL result: snowpark_df = cell1.to_df()
Convert the result to a Pandas dataframe: my_df = cell1.to_pandas()
|
Referencing variables in SQL code:
Important
In SQL code, you can only reference Python variables of type string
. You cannot reference a Snowpark DataFrame, pandas DataFrame or
other Python native DataFrame format.
Reference cell type |
Current cell type |
Reference syntax |
Example |
---|---|---|---|
SQL |
SQL |
|
For example, in a SQL cell named SELECT * FROM {{cell2}} where PRICE > 500
|
Python |
SQL |
|
For example, in a Python cell named c = "USA"
You can reference the value of the variable SELECT * FROM my_table WHERE COUNTRY = {{c}}
|
Considerations for running notebooks¶
Notebooks run using caller’s rights. For additional considerations, see Changing the session context for a notebook.
You can import Python libraries to use in a notebook. For details, see Import Python packages to use in notebooks.
When referencing objects in SQL cells, you must use fully qualified object names, unless you are referencing object names in a specified database or schema. See Changing the session context for a notebook.
Notebook drafts are saved every three seconds.
After one hour of inactivity (not editing code or executing queries), the notebook kernel will shut down. Snowflake also recommends that you check the parameters on your warehouse. If STATEMENT_TIMEOUT_IN_SECONDS or STATEMENT_QUEUED_TIMEOUT_IN_SECONDS is set to a small value, the notebook could shut down or fail to start.
You can use Git integration to maintain notebook versions.
For Python cells, non-linear cell execution order and global referencing are not supported. You must define and run a Python variable in a cell before referencing it in a subsequent cell. For example, to reference a Python variable in cell 2, the variable must be previously declared in cell 1 and the cells must be executed in order. This behavior differs from other notebooks such as Jupyter, where out-of-order execution is supported, meaning that once a variable is declared, it can be used anywhere in the notebook.
Notebook cell results are cached across sessions. Reopening a notebook displays past results from the last time you ran the notebook using the UI. The cached results are only visible for the same user that ran the notebook.
BEGIN … END (Snowflake Scripting) is not supported in SQL cells. Instead, use the Session.sql().collect() method in a Python cell to run the scripting block. Chain the
sql
call with a call tocollect
to immediately execute the SQL query.The following code runs a Snowflake scripting block using the
session.sql().collect()
method:from snowflake.snowpark.context import get_active_session session = get_active_session() code_to_run = """ BEGIN CALL TRANSACTION_ANOMALY_MODEL!DETECT_ANOMALIES( INPUT_DATA => SYSTEM$REFERENCE('TABLE', 'ANOMALY_INFERENCE'), TIMESTAMP_COLNAME =>'DATE', TARGET_COLNAME => 'TRANSACTION_AMOUNT', CONFIG_OBJECT => {'prediction_interval': 0.95} ); LET x := SQLID; CREATE TABLE ANOMALY_PREDICTIONS AS SELECT * FROM TABLE(RESULT_SCAN(:x)); END; """ data = session.sql(code_to_run).collect(block=True);