Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
This article describes the functions available to help you navigate the Databricks notebook and file editor, including keyboard shortcuts, code suggestions and autocomplete, variable inspection, and code folding. When you use the notebook or the file editor, Databricks Assistant is available to help you generate, explain, and debug code. See Get coding help from Databricks Assistant for details.
You can choose from a selection of editor themes. Select View > Editor theme and make a selection from the menu.
Command palette
You can quickly perform actions in the notebook using the command palette. To open a panel of notebook actions, click  in the lower-right corner of the workspace or use the shortcut Cmd + Shift + P on MacOS or Ctrl + Shift + P on Windows.

Cell execution minimap
To get a visual overview of your notebook’s execution status, use the cell execution minimap. The minimap appears in the right margin and shows a status bar for each executable cell.
Status bars indicate the following execution states:
- Light grey: Cell is static.
- Dark grey: Cell is either skipped or queued for execution.
- Light grey with moving bar: Cell is currently running.
- Green: Cell ran successfully without errors.
- Red: Cell failed with an error.
To interact with the minimap:
- Hover over the minimap to see a list of executable cells, their titles, and their execution states.
- Click an entry to jump directly to that cell in the notebook.
- Click Go to last run cell or Go to first failed cell to navigate to the most recently run or first failed cell.
The minimap helps you track execution progress at a glance and quickly navigate while debugging or developing.

Find and replace text
To find and replace text within a notebook, use the keyboard shortcut, Cmd + F (Mac) or Ctrl + F(Windows), or click Edit > Find... to open the Find dialog box. Enter the text you want to find. The current match is highlighted in orange and all other matches are highlighted in yellow. To access the native browser search, press Cmd + F (Mac) or Ctrl + F(Windows) again.
Click the  to open the Replace option. Enter the text you want to use instead. To replace the current match, click Replace. To replace all matches in the notebook, click Replace All.
To move between matches, click  (previous match) or 
 (next match). You can also press 
Shift + Enter and Enter to go to the previous and next matches, respectively.
To close the find and replace tool, click  or press esc.
Variable inspection
To display information about a variable defined in a SQL or Python notebook, hover your cursor over the variable name. Python variable inspection requires Databricks Runtime 12.2 LTS or above.

See Variable explorer.
Go to definition
When a Python notebook is attached to a compute resource, you can quickly go to the definition of a variable, function, or the code behind a %run statement. To do this, right-click the variable or function name, and then click Go to definition or Peek definition.
Hold down the Cmd key on macOS or the Ctrl key on Windows and hover over the variable or function name. If a definition is found, the name turns into a hyperlink.

The “go to definition” feature is available in Databricks Runtime 12.2 LTS and above.
Code folding
Code folding lets you temporarily hide sections of code. This can be helpful when working with long code blocks because it lets you focus on specific sections of code you are working on.
To hide code, place your cursor at the far left of a cell. Downward-pointing arrows appear at logical points where you can hide a section of code. Click the arrow to hide a code section. Click the arrow again (now pointing to the right) to show the code.

For more details, including keyboard shortcuts, see the VS Code documentation.
Multicursor support
You can create multiple cursors to make simultaneous edits easier, as shown in the video:

To create multiple cursors in a cell:
- On macOS, hold down the Optionkey and click in each location to add a cursor.
- On Windows, hold down the Altkey and click in each location to add a cursor.
- You also have the option to change the shortcut. See Change shortcut for multicursor and column selection.
On macOS, you can create multiple vertically aligned cursors by using the keyboard shortcut Option+Command+ up or down arrow key.
Column (box) selection
To select multiple items in a column, click at the upper left of the area you want to capture. Then:
- On macOS, press Shift+Optionand drag to the lower right to capture one or more columns.
- On Windows, press Shift+Altand drag to the lower right to capture one or more columns.
- You also have the option to change the shortcut. See Change shortcut for multicursor and column selection.

Change shortcut for multicursor and column selection
An alternate shortcut is available for multicursor and column (box) selection. With the alternate selection, the shortcuts change as follows:
- To create multiple cursors in a cell:
- On macOS, hold down the Cmdkey and click in each location to add a cursor.
- On Windows, hold down the Ctrlkey and click in each location to add a cursor.
 
- On macOS, hold down the 
- To select multiple items in a column, click at the upper left of the area you want to capture. Then:
- On macOS, press Optionand drag to the lower right to capture one or more columns.
- On Windows, press Altand drag to the lower right to capture one or more columns.
 
- On macOS, press 
To enable the alternate shortcuts, do the following:
- Click your username at the upper-right of the workspace, then click Settings in the dropdown list.
- In the Settings sidebar, select Developer.
- In the Code editor section, change the Key modifier for multi-cursor click setting to Cmd for macOS or Ctrl for Windows.
When you enable alternate shortcuts, the keyboard shortcut for creating multiple vertically aligned cursors does not change.
Browse data
Use the schema browser to explore Unity Catalog objects available for the notebook. Click  at the left side of the notebook to open the schema browser.
The For you button displays only those objects that you've used in the current session or previously marked as a Favorite.
As you type text into the Filter box, the display changes to show only those objects that contain the text you type. Only objects that are currently open or have been opened in the current session appear. The Filter box does not do a complete search of the catalogs, schemas, tables, and volumes available for the notebook.
To open the  kebab menu, hover the cursor over the object's name as shown:

If the object is a table, you can do the following:
- Automatically create and run a cell to display a preview of the data in the table. Select Preview in a new cell from the kebab menu for the table.
- View a catalog, schema, or table in Catalog Explorer. Select Open in Catalog Explorer from the kebab menu. A new tab opens showing the selected object.
- Get the path to a catalog, schema, or table. Select Copy … path from the kebab menu for the object.
- Add a table to Favorites. Select Add to favorites from the kebab menu for the table.
If the object is a catalog, schema, or volume, you can copy the object's path or open it in Catalog Explorer.
To insert a table or column name directly into a cell:
- Click your cursor in the cell at the location you want to enter the name.
- Move your cursor over the table name or column name in the schema browser.
- Click the double arrow that appears at the right of the object's name. 
Use web terminal and Databricks CLI
To open the web terminal in a notebook, click the terminal icon  at the bottom of the right sidebar.
In Databricks Runtime 15.0 and above, you can use the Databricks CLI from the web terminal in a notebook. See Run shell commands in Azure Databricks web terminal for requirements and usage information.
You cannot use the CLI from a notebook cell. In a notebook, commands like %sh databricks ... do not work with Databricks Runtime 15.0 or above.
Personalized autocomplete
Autocomplete automatically completes code segments as you type them. Completable objects include types, classes, and objects, as well as SQL database, table names, structs, maps, arrays, and query snippets. When referencing common table expressions (CTEs) that use SELECT *, autocomplete provides column recommendations based on the underlying table structure. Databricks uses your Unity Catalog metadata and usage to personalize suggestions.
- For Python cells, the notebook must be attached to a compute resource for autocomplete to work, and you must run all cells that define completable objects.
- For SQL cells, autocomplete suggests keywords and basic syntax even if the notebook is not attached to any compute resource.
- If the workspace is enabled for Unity Catalog, autocomplete also suggests catalog, schema, table, and column names for tables in Unity Catalog.
- If the workspace is not enabled for Unity Catalog, the notebook must be attached to an all-purpose compute resource or a SQL warehouse to suggest table or column names.
 
Autocomplete suggestions automatically appear when you type in a cell. Use the up and down arrow keys or your mouse to select a suggestion, and press Tab or Enter to insert the selection into the cell.
Note
Server autocomplete in R notebooks is blocked during command execution.
Autocomplete is enabled by default but can be disabled in your user settings:
- To turn off autocomplete suggestions, toggle Autocomplete as you type. When autocomplete is off, you can display autocomplete suggestions by pressing Ctrl + Space.
- To prevent Enter from inserting autocomplete suggestions, toggle Enter key accepts autocomplete suggestions.
Bracket matching
When you click near a parenthesis, square bracket, or curly brace, the editor highlights that character and its matching bracket.

Python error highlighting

Workspaces with Partner-powered AI features enabled can also select Fix with Assistant for AI-assisted suggestions.
Databricks notebooks support the following error highlighting:
- Python syntax error highlighting: Any syntax errors in Python code cells are highlighted in red. If possible, the Assistant will suggest a quick fix for you. This is supported for compute running Databricks Runtime 12.1 and above or serverless compute. You can configure syntax error highlighting with pyproject.tomlfiles. See Configure Python syntax highlighting.
- Python format error highlighting: Python code formatting errors and warnings are underlined in yellow or red, depending on severity. This can help identify formatting issues such as unexpected indentation, long line length, and more. Hover over the syntax warnings to see more information. This is supported for compute running Databricks Runtime 12.1 and above or serverless compute.
- Python type error highlighting: Type checking can improve code quality, readability, and maintainability in Python and PySpark projects. Type checkers can flag errors related to non-existent attributes, missing arguments, and mismatched arguments in function calls before code execution. Hover over the highlighted warnings to see more information. This is supported for compute running Databricks Runtime 16.0 and above or serverless environment 2.
Enable Python error highlighting
To enable or disable error highlighting, do the following:
- Click your username at the upper-right of the workspace, then click Settings in the dropdown list.
- In the Settings sidebar, select Developer.
- Toggle the setting for Python syntax error highlighting (under Code editor), Python format error highlighting (under Experimental features), and/or Python type error highlighting (under Experimental features).
Configure Python syntax highlighting
When a notebook is connected to compute running Databricks Runtime 16.4 or above or serverless environment version 3 or above, you can customize the behavior of syntax highlighting by creating a pyproject.toml file. For a given notebook, the closest pyproject.toml file in its direct ancestor path in the Workspace File System will be used. If one cannot be found in the ancestor path, then a pyproject.toml file in the current user's home folder will be used.
For example, if you have a notebook with the path a/b/c/d/notebook.py and there are pyproject.toml files at a/b/pyproject.toml and a/b/c/pyproject.toml then the second one will be used since it is closer. A pyproject.toml file at /a/b/c/e/pyproject.toml would not be considered because it is not in the direct ancestor path.
Azure Databricks uses standard syntax for pyproject.toml files. For example, you can refer to the Ruff documentation to see how to configure the Ruff linter with a pyproject.toml file.
Currently, Azure Databricks only supports configuring ruff, pylint, pyright and flake8 for linting through pyproject.toml.
To enable a linter, the pyproject.toml file needs to have a [tool.<name-of-linter>] block.
To explicitly disable a linter, add the following block:
[tool.<name-of-linter>]
disabled=true
You can also disable Azure Databricks-written syntax highlighting rules with a block such as:
[tool.databricks]
disabled_rules = ['DB01', 'DB03']
Because Flake8 expects a configuration in a different format, you have to pass in the configuration for Flake8 as a string:
[tool.flake8]
config = """ \
[flake8] \
extend_ignore = E303 \
"""
Customize SQL formatting
You can customize settings for SQL formatting in new SQL editor and the notebook editor. Click View > Developer Settings. Scroll down to SQL Format and specify your settings.

Use keyboard shortcuts
To display keyboard shortcuts, select Help > Keyboard shortcuts. The keyboard shortcuts available depend on whether the cursor is in a code cell (edit mode) or not (command mode).
The tables below show available keyboard shortcuts.
Edit mode shortcuts
| Function | MacOS shortcut | Windows shortcut | 
|---|---|---|
| Switch to Command Mode | Esc | Esc | 
| Run command and insert new cell below | Option+Enter | Alt+Enter | 
| Insert a cell above | Ctrl+Option+P | Ctrl+Alt+P | 
| Insert a cell below | Ctrl+Option+N | Ctrl+Alt+N | 
| Move to previous/next cell | Option+Up/Down | Alt+Up/Down | 
| Split a cell at cursor | Ctrl+Option+- | Ctrl+Alt+- | 
| Delete current line | ⌘+Shift+K | Ctrl+Shift+K | 
| Delete current cell | Ctrl+Option+D | Ctrl+Alt+D | 
| Move up or to previous cell | Up | Up | 
| Move down or to next cell | Down | Down | 
| Autocomplete | Ctrl+Space | Ctrl+Space | 
| Automatic Assistant Autocomplete | Ctrl+Shift+Space | Ctrl+Shift+Space | 
| Inline Assistant | ⌘+I | Ctrl+I | 
| Parameter hints | ⌘+Shift+Space | Ctrl+Shift+Space | 
| Docstring | ⌘+ (K,I) | Ctrl+ (K,I) | 
| Multiple cursors | Option+Click | Alt+Click | 
| Column (box) select | Option+Shift+Drag | Alt+Shift+Drag | 
| Indent/Unindent selection | ⌘+]/[ | Ctrl+]/[ | 
| Undo typing | ⌘+Z | Ctrl+Z | 
| Redo typing | ⌘+Shift+Z | Ctrl+Shift+Z | 
| Toggle line comment | ⌘+/ | Ctrl+/ | 
| Add line comment | ⌘+ (K,C) | Ctrl+ (K,C) | 
| Remove line comment | ⌘+ (K,U) | Ctrl+ (K,U) | 
| Multi-cursor edit | ⌘+Option+Up/Down | Ctrl+Option+Up/Down | 
| Increase font size | Option++ | Alt++ | 
| Decrease font size | Option+- | Alt+- | 
Command mode shortcuts
| Function | Mac OS shortcut | Windows shortcut | 
|---|---|---|
| Switch to Edit Mode | Enter | Enter | 
| Cancel execution for selected cells | I,I | I,I | 
| Cancel execution (skip prompt) | Shift+ (I,I) | Shift+ (I,I) | 
| Delete current cell | D,D | D,D | 
| Delete current cell (skip prompt) | Shift+ (D,D) | Shift+ (D,D) | 
| Go to first cell | G,G | G,G | 
| Go to last cell | Shift+G | Shift+G | 
| Undo cut/delete cells | ⌘+Z/Z | Ctrl+Z/Z | 
| Copy current cell | ⌘+C | Ctrl+C | 
| Cut current cell | ⌘+X | Ctrl+X | 
| Paste cell | ⌘+V | Ctrl+V | 
| Insert a cell above | A | A | 
| Insert a cell below | B | B | 
| Toggle cell output | O | O | 
| Toggle cell title | T | T | 
| Scroll down | Space | Space | 
| Scroll up | Shift+Space | Shift+Space | 
| Toggle keyboard shortcuts menu | H | H | 
| Merge with cell below | Shift+M | Shift+M | 
| Move to previous cell | Up/P/K | Up/P/K | 
| Move to next cell | Down/N/J | Down/N/J | 
| Add adjacent cell to selection | Shift+Up/Down | Shift+Up/Down | 
| Select all cells | ⌘+A | Ctrl+A | 
| Select multiple cells | ⌘+Click | Ctrl+Click | 
| Toggle line numbers | L | L | 
| Expand/Collapse cell headings | Right/Left | Right/Left | 
Shared shortcuts
| Function | MacOS shortcut | Windows shortcut | 
|---|---|---|
| Toggle command palette | ⌘+Shift+P | Ctrl+Shift+P | 
| Find | ⌘+F | Ctrl+F | 
| Replace | Ctrl+Option+F | Ctrl+Alt+F | 
| Format code | ⌘+Shift+F | Ctrl+Shift+F | 
| Run command and move to next cell | Shift+Enter | Shift+Enter | 
| Run selected command(s) | ⌘+Enter | Ctrl+Enter | 
| Debug cell | Option+Shift+D | Alt+Shift+D | 
| Debugger: Continue | F7 | F7 | 
| Debugger: Next Line | F8 | F8 | 
| Debugger: Step Into | F9 | F9 | 
| Debugger: Step Out | Shift+F9 | Shift+F9 | 
| Run all commands | Option+Shift+Enter | Alt+Shift+Enter | 
| Run all above commands (exclusive) | Option+Shift+Up | Alt+Shift+Up | 
| Run all below commands (inclusive) | Option+Shift+Down | Alt+Shift+Down | 
| Clear state and outputs | 0,0 | 0,0 | 
| Run selected text or active statement | Ctrl+Shift+Enter | Ctrl+Shift+Enter | 
| Run active SQL statement | ⌘+Shift+Enter | Ctrl+Shift+Enter | 
| Move a cell up | Ctrl+Option+Up | Ctrl+Alt+Up | 
| Move a cell down | Ctrl+Option+Down | Ctrl+Alt+Down | 
| Toggle comments panel / add comment | Ctrl+Option+M | Ctrl+Alt+M | 
| Toggle workspace panel | Ctrl+Option+E | Ctrl+Alt+E | 
| Toggle catalog panel | Ctrl+Option+C | Ctrl+Alt+C | 
| Toggle assistant panel | Ctrl+Option+A | Ctrl+Alt+A | 
| Toggle focus mode | Ctrl+Option+O | Ctrl+Alt+O | 
| Close current tab | Ctrl+Option+W | Ctrl+Alt+W | 
| Create new tab | Ctrl+Option+T | Ctrl+Alt+T | 
| Switch to left tab | Ctrl+Option+Left | Ctrl+Alt+Left | 
| Switch to right tab | Ctrl+Option+Right | Ctrl+Alt+Right | 
| Close all tabs | Ctrl+Option+Shift+A | Ctrl+Alt+Shift+A |