---
obj: application
website: https://yazi-rs.github.io
repo: https://github.com/sxyazi/yazi
rev: 2024-03-14
---

# Yazi
Yazi (means "duck") is a terminal file manager written in [Rust](../../dev/programming/languages/Rust.md), based on non-blocking async I/O. It aims to provide an efficient, user-friendly, and customizable file management experience.

## Features
- πŸš€ Full Asynchronous Support: All I/O operations are asynchronous, CPU tasks are spread across multiple threads, making the most of available resources.
- πŸ’ͺ Powerful Async Task Scheduling and Management: Provides real-time progress updates, task cancellation, and internal task priority assignment.
- πŸ–ΌοΈ Built-in Support for Multiple Image Protocols: Also integrated with Überzug++, covering almost all terminals.
- 🌟 Built-in Code Highlighting and Image Decoding: Combined with the pre-loading mechanism, greatly accelerates image and normal file loading.
- πŸ”Œ Concurrent Plugin System: UI plugins (rewriting most of the UI), functional plugins, custom previewer, and custom preloader; Just some pieces of Lua.
- 🧰 Integration with [fd](fd.md), [rg](ripgrep.md), fzf, zoxide
- πŸ’« Vim-like input/select/notify component, auto-completion for cd paths
- 🏷️ Multi-Tab Support, Cross-directory selection, Scrollable Preview (for videos, PDFs, archives, directories, code, etc.)
- πŸ”„ Bulk Renaming, Visual Mode, File Chooser
- 🎨 Theme System, Custom Layouts, Trash Bin, CSI u
- ... and more!

![Screenshot](./yazi.avif)

## Dependencies
To use Yazi, you must have the following prerequisites installed:
- [`file`](system/file.md) (for file type detection)

Yazi can be optionally extended with other command line tools to enable additional features.
- `nerd-fonts` (recommended)
- `ffmpegthumbnailer` (for video thumbnails)
- `unar` (for archive preview)
- [`jq`](jq.md) (for [JSON](../../files/JSON.md) preview)
- `poppler` (for [PDF](../../files/PDF.md) preview)
- [`fd`](fd.md) (for file searching)
- [`rg`](ripgrep.md) (for file content searching)
- `fzf` (for quick file subtree navigation)
- `zoxide` (for historical directories navigation)

## Shell Wrapper
We suggest using this ya [shell](Shell.md) wrapper that provides the ability to change the current working directory when exiting Yazi.
```shell
function ya() {
	local tmp="$(mktemp -t "yazi-cwd.XXXXX")"
	yazi "$@" --cwd-file="$tmp"
	if cwd="$(cat -- "$tmp")" && [ -n "$cwd" ] && [ "$cwd" != "$PWD" ]; then
		cd -- "$cwd"
	fi
	rm -f -- "$tmp"
}
```

## Keybindings
### Navigation
To navigate between files and directories you can use the arrow keys `←`, `↑`, `↓` and `β†’` or Vim-like commands such as `h`, `j`, `k`, `l`:

| Key binding | Alternate key | Action                                          |
| ----------- | ------------- | ----------------------------------------------- |
| `k`         | `↑`           | Move the cursor up                              |
| `j`         | `↓`           | Move the cursor down                            |
| `l`         | `β†’`           | Enter hovered directory                         |
| `h`         | `←`           | Leave the current directory and into its parent |

Further navigation commands can be found in the table below.

| Key binding | Action                       |
| ----------- | ---------------------------- |
| `K`         | Move the cursor up 5 lines   |
| `J`         | Move the cursor down 5 lines |
| `g` β‡’ `g`   | Move cursor to the top       |
| `G`         | Move cursor to the bottom    |

### Selection
To select files and directories, the following commands are available.

| Key binding | Action                                     |
| ----------- | ------------------------------------------ |
| `<Space>`   | Toggle selection of hovered file/directory |
| `v`         | Enter visual mode (selection mode)         |
| `V`         | Enter visual mode (unset mode)             |
| `<Ctrl-a>`  | Select all files                           |
| `<Ctrl-r>`  | Inverse selection of all files             |
| `<Esc>`     | Cancel selection                           |

### File/directory operations
To interact with selected files/directories use any of the commands below.

| Key binding    | Action                                                                      |
| -------------- | --------------------------------------------------------------------------- |
| `o`            | Open the selected files                                                     |
| `O`            | Open the selected files interactively                                       |
| `<Enter>`      | Open the selected files                                                     |
| `<Ctrl-Enter>` | Open the selected files interactively (some terminals don't support it yet) |
| `y`            | Yank the selected files (copy)                                              |
| `x`            | Yank the selected files (cut)                                               |
| `p`            | Paste the yanked files                                                      |
| `P`            | Paste the yanked files (overwrite if the destination exists)                |
| `-`            | Create a symbolic link to the yanked files (absolute path)                  |
| `_`            | Create a symbolic link to the yanked files (relative path)                  |
| `d`            | Move the files to the trash                                                 |
| `D`            | Permanently delete the files                                                |
| `a`            | Create a file or directory (ends with "/" for directories)                  |
| `r`            | Rename a file or directory                                                  |
| `;`            | Run a [shell](Shell.md) command                                             |
| `:`            | Run a [shell](Shell.md) command (block the UI until the command finishes)   |
| `.`            | Toggle the visibility of hidden files                                       |
| `<Ctrl-s>`     | Cancel the ongoing search                                                   |
| `z`            | Jump to a directory using zoxide                                            |
| `Z`            | Jump to a directory, or reveal a file using fzf                             |
| `w`            | Show task manager                                                           |

### Copying paths
To copy paths, use any of the following commands below.

> _Observation: `c β‡’ d` indicates pressing the `c` key followed by pressing the `d` key._

| Key binding | Action                                          |
| ----------- | ----------------------------------------------- |
| `c` β‡’ `c`   | Copy absolute path                              |
| `c` β‡’ `d`   | Copy the path of the parent directory           |
| `c` β‡’ `f`   | Copy the name of the file                       |
| `c` β‡’ `n`   | Copy the name of the file without the extension |

### Filtering files/directories
| Key binding | Action                              |
| ----------- | ----------------------------------- |
| `f`         | Filter the files/directories in CWD |

### Finding files/directories
| Key binding | Action                              |
| ----------- | ----------------------------------- |
| `/`         | Forward find file/directory in CWD  |
| `?`         | Backward find file/directory in CWD |
| `n`         | Jump to next occurrence             |
| `N`         | Jump to previous occurrence         |

### Searching files/directories
| Key binding | Action                                                                         |
| ----------- | ------------------------------------------------------------------------------ |
| `s`         | Search files by name using [fd](https://github.com/sharkdp/fd)                 |
| `S`         | Search files by content using [ripgrep](https://github.com/BurntSushi/ripgrep) |

### Sorting
To sort files/directories use the following commands.

> _Observation: `, β‡’ a` indicates pressing the `,` key followed by pressing the `a` key._

| Key binding | Action                           |
| ----------- | -------------------------------- |
| `,` β‡’ `m`   | Sort by modified time            |
| `,` β‡’ `M`   | Sort by modified time (reverse)  |
| `,` β‡’ `c`   | Sort by creation time            |
| `,` β‡’ `C`   | Sort by creation time (reverse)  |
| `,` β‡’ `e`   | Sort by file extension           |
| `,` β‡’ `E`   | Sort by file extension (reverse) |
| `,` β‡’ `a`   | Sort alphabetically              |
| `,` β‡’ `A`   | Sort alphabetically (reverse)    |
| `,` β‡’ `n`   | Sort naturally                   |
| `,` β‡’ `N`   | Sort naturally (reverse)         |
| `,` β‡’ `s`   | Sort by size                     |
| `,` β‡’ `S`   | Sort by size (reverse)           |

### Line Mode
You can change the output of the line mode with the following commands:

| Key binding | Action                      |
| ----------- | --------------------------- |
| `ms`        | Set linemode to size        |
| `mp`        | Set linemode to permissions |
| `mm`        | Set linemode to mtime       |
| `mn`        | Set linemode to none        |

### Changing directories
You can quickly change directories with these commands:

| Key binding   | Action                          |
| ------------- | ------------------------------- |
| `gh`          | Go to the home directory        |
| `gc`          | Go to the config directory      |
| `gd`          | Go to the downloads directory   |
| `gt`          | Go to the temporary directory   |
| `g + <Space>` | Go to a directory interactively |

### Tabs
You can use tabs with the following commands:

| Key binding | Action                                     |
| ----------- | ------------------------------------------ |
| `<Ctrl-q>`  | Close current tab                          |
| `t`         | Create a new tab using current path        |
| `1-9`       | Switch to tab with number                  |
| `[`         | Switch to the previous tab                 |
| `]`         | Switch to the next tab                     |
| `{`         | Swap the current tab with the previous tab |
| `}`         | Swap the current tab with the next tab     |

## Configuration
There are three configuration files for Yazi:
- `yazi.toml` - General configuration.
- `keymap.toml` - Keybindings configuration.
- `theme.toml` - Color scheme configuration.

You can find the default configuration files at https://github.com/sxyazi/yazi/tree/latest/yazi-config/preset.
You can change the Yazi configuration directory by exporting the `YAZI_CONFIG_HOME` environment variable.