zoxide
A faster way to navigate your filesystem
Table of contents
Introduction
zoxide is a blazing fast alternative to cd, inspired by
z and z.lua.
It keeps track of the directories you use most frequently, and uses a ranking algorithm
to navigate to the best match.

Examples
Getting started
Step 1: Installing zoxide
On Arch Linux 
On CentOS
On DragonFly BSD 
On Fedora 32+ 
On FreeBSD 
On macOS / Linux (via Homebrew / Linuxbrew) 
On macOS (via MacPorts) 
On NixOS 
On Void Linux 
On Windows (via Scoop) 
scoop install zoxide
Other (via Cargo) 
Other (via precompiled binary) 
Use the installation script:
|
Alternatively, you can also download a precompiled binary from the
releases page and add it to
your PATH.
Step 2: Installing fzf (optional)
If you want to use interactive fuzzy selection, you will also need to install
fzf.
Step 3: Adding zoxide to your shell
If you currently use z, z.lua, or zsh-z, you may want to first import
your existing database into zoxide:
bash
Add the following line to your ~/.bashrc:
fish
Add the following line to your ~/.config/fish/config.fish:
|
POSIX shells
Add the following line to your shell's configuration file:
PowerShell
Add the following line to your profile:
Invoke-Expression (& {
$hook = if ($PSVersionTable.PSVersion.Major -lt 6) { 'prompt' } else { 'pwd' }
(zoxide init --hook $hook powershell) -join "`n"
})
xonsh
Add the following line to your profile (usually ~/.xonshrc):
execx($(zoxide init xonsh), 'exec', __xonsh__.ctx, filename='zoxide')
zsh
Add the following line to your ~/.zshrc:
Configuration
init flags
--cmd: change thezcommand (and corresponding aliases) to something else--hook <HOOK>: change the event that adds a new entry to the database (default:pwd)none: never add entries (this will makezoxideuseless unless you manually configure a hook)prompt: add an entry at every promptpwd: add an entry whenever the current directory is changed
--no-aliases: don't define extra aliases likezi,zq,za, andzr
Environment variables
$_ZO_DATA_DIR: directory wherezoxidewill store its data files (default: platform-specific; see thedirsdocumentation for more information)$_ZO_ECHO: when set to1,zwill print the matched directory before navigating to it$_ZO_EXCLUDE_DIRS: list of directories separated by platform-specific characters (":" on Linux/macOS, ";" on Windows) to be excluded from the database$_ZO_FZF_OPTS: custom flags to pass tofzf$_ZO_MAXAGE: sets the maximum total age after which entries start getting deleted$_ZO_RESOLVE_SYMLINKS: when set to1,z addwill resolve symlinks.