#
Obsidian CLI
Obsidian CLI is a command line interface that lets you control Obsidian from your terminal for scripting, automation, and integration with external tools.
Anything you can do in Obsidian can be done from the command line. Obsidian CLI even includes
Early access feature
Obsidian CLI requires Obsidian 1.12 or above, which is currently an early access version and requires a Catalyst license. Commands and syntax are likely to change during the early access phase.
#
Install Obsidian CLI
Upgrade to the latest Obsidian installer version (1.11.7) and the latest early access version (1.12.x).
Enable Obsidian CLI in Obsidian:
- Go to Settings → General.
- Enable Command line interface.
- Follow the prompt to register Obsidian CLI.
On Windows you will also need to run the .com file, available to Catalyst members on Discord. See
#
Get started
Obsidian CLI supports both single commands and a terminal user interface (TUI) with interactive help and autocomplete.
Obsidian app must be running
Obsidian CLI requires the Obsidian app to be running. If Obsidian is not running, the first command you run launches Obsidian.
#
Run a command
Run an individual command without opening the TUI:
# Run the help command
obsidian help
#
Use the terminal interface
Use the TUI by entering obsidian. Subsequent commands can be entered without obsidian.
# Open the TUI, then run help
obsidian
help
The TUI supports autocomplete, command history, and reverse search. Use Ctrl+R to search your command history. See
#
Examples
Here are a few examples of what Obsidian CLI can do.
#
Everyday use
# Open today's daily note
obsidian daily
# Add a task to your daily note
obsidian daily:append content="- [ ] Buy groceries"
# Search your vault
obsidian search query="meeting notes"
# Read the active file
obsidian read
# List all tasks from your daily note
obsidian tasks daily
# Create a new note from a template
obsidian create name="Trip to Paris" template=Travel
# List all tags in your vault with counts
obsidian tags counts
# Compare two versions of a file
obsidian diff file=README from=1 to=3
#
For developers
Many
# Open developer tools
obsidian devtools
# Reload a community plugin you're developing
obsidian plugin:reload id=my-plugin
# Take a screenshot of the app
obsidian dev:screenshot path=screenshot.png
# Run JavaScript in the app console
obsidian eval code="app.vault.getFiles().length"
#
How to
#
Use parameters and flags
Commands can use parameters and flags. Most commands do not require any parameters or flags. Required parameters are marked as required. For example:
# Create a new note using the default "Untitled" name
obsidian create
A parameter takes a value, written as parameter=value. If the value has spaces, wrap it in quotes:
# Create a new note called "Note" with content "Hello world"
obsidian create name=Note content="Hello world"
A flag is a boolean switch with no value. Include it to turn it on, for example open and overwrite are flags:
# Create a note and open it
obsidian create name=Note content="Hello" open overwrite
For multiline content use \n for newline. Use \t for tab.
obsidian create name=Note content="# Title\n\nBody text"
#
Target a vault
If your terminal's current working directory is a vault folder, that vault is used by default. Otherwise, the currently active vault is used.
Use vault=<name> or vault=<id> to target a specific vault. This must be the first parameter before your command:
obsidian vault=Notes daily
obsidian vault="My Vault" search query="test"
In the TUI, use vault:open <name> or <id> to switch to a different vault.
#
Target a file
Many commands accept file and path parameters to target a specific file. If neither is provided, the command defaults to the active file.
file=<name>resolves the file using the same link resolution as wikilinks, matching by file name without requiring the full path or extension.path=<path>requires the exact path from the vault root, e.g.folder/note.md.
# These are equivalent if "Recipe.md" is the only file with that name
obsidian read file=Recipe
obsidian read path="Templates/Recipe.md"
#
Copy output
Add --copy to any command to copy the output to the clipboard:
read --copy
search query="TODO" --copy
#
General commands
#
help
Show list of all available commands.
#
version
Show Obsidian version.
#
reload
Reload the app window.
#
restart
Restart the app.
#
Bases
Commands for Bases.
#
bases
List all .base files in the vault.
#
base:views
List views in the current base file.
#
base:create
Create a new item in a base. Defaults to the active base view if no file is specified.
file=<name> # base file name
path=<path> # base file path
view=<name> # view name
name=<name> # new file name
content=<text> # initial content
open # open file after creating
newtab # open in new tab
#
base:query
Query a base and return results.
file=<name> # base file name
path=<path> # base file path
view=<name> # view name to query
format=json|csv|tsv|md|paths # output format (default: json)
#
Bookmarks
Commands for Bookmarks.
#
bookmarks
List bookmarks.
total # return bookmark count
verbose # include bookmark types
format=json|tsv|csv # output format (default: tsv)
#
bookmark
Add a bookmark.
file=<path> # file to bookmark
subpath=<subpath> # subpath (heading or block) within file
folder=<path> # folder to bookmark
search=<query> # search query to bookmark
url=<url> # URL to bookmark
title=<title> # bookmark title
#
Command palette
Commands for Command palette and Hotkeys. This includes all commands registered by plugins.
#
commands
List available command IDs.
filter=<prefix> # filter by ID prefix
#
command
Execute an Obsidian command.
id=<command-id> # (required) command ID to execute
#
hotkeys
List hotkeys for all commands.
total # return hotkey count
verbose # show if hotkey is custom
format=json|tsv|csv # output format (default: tsv)
#
hotkey
Get hotkey for a command.
id=<command-id> # (required) command ID
verbose # show if custom or default
#
Daily notes
Commands for Daily notes.
#
daily
Open daily note.
paneType=tab|split|window # pane type to open in
#
daily:path
Get daily note path. Returns the expected path even if the file hasn't been created yet.
#
daily:read
Read daily note contents.
#
daily:append
Append content to daily note.
content=<text> # (required) content to append
paneType=tab|split|window # pane type to open in
inline # append without newline
open # open file after adding
#
daily:prepend
Prepend content to daily note.
content=<text> # (required) content to prepend
paneType=tab|split|window # pane type to open in
inline # prepend without newline
open # open file after adding
#
File history
#
diff
List or compare versions from local File recovery and Sync. Versions are numbered from newest to oldest.
file=<name> # file name
path=<path> # file path
from=<n> # version number to diff from
to=<n> # version number to diff to
filter=local|sync # filter by version source
Examples:
# List all versions of the active file
diff
# List all versions of a specific file
diff file=Recipe
# Compare the latest version to the current file
diff file=Recipe from=1
# Compare two versions
diff file=Recipe from=2 to=1
# Only show Sync versions
diff filter=sync
#
history
List versions from File recovery only. See
file=<name> # file name
path=<path> # file path
#
history:list
List all files with local history.
#
history:read
Read a local history version.
file=<name> # file name
path=<path> # file path
version=<n> # version number (default: 1)
#
history:restore
Restore a local history version.
file=<name> # file name
path=<path> # file path
version=<n> # (required) version number
#
history:open
Open file recovery.
file=<name> # file name
path=<path> # file path
#
Files and folders
#
file
Show file info (default: active file).
file=<name> # file name
path=<path> # file path
Example:
path Notes/Recipe.md
name Recipe
extension md
size 1024
created 1700000000000
modified 1700001000000
#
files
List files in the vault.
folder=<path> # filter by folder
ext=<extension> # filter by extension
total # return file count
#
folder
Show folder info.
path=<path> # (required) folder path
info=files|folders|size # return specific info only
#
folders
List folders in the vault.
folder=<path> # filter by parent folder
total # return folder count
#
open
Open a file.
file=<name> # file name
path=<path> # file path
newtab # open in new tab
#
create
Create or overwrite a file.
name=<name> # file name
path=<path> # file path
content=<text> # initial content
template=<name> # template to use
overwrite # overwrite if file exists
open # open file after creating
newtab # open in new tab
#
read
Read file contents (default: active file).
file=<name> # file name
path=<path> # file path
#
append
Append content to a file (default: active file).
file=<name> # file name
path=<path> # file path
content=<text> # (required) content to append
inline # append without newline
#
prepend
Prepend content after frontmatter (default: active file).
file=<name> # file name
path=<path> # file path
content=<text> # (required) content to prepend
inline # prepend without newline
#
move
Move or rename a file (default: active file). This will automatically update internal links if turned on in your vault settings.
file=<name> # file name
path=<path> # file path
to=<path> # (required) destination folder or path
#
rename
Rename a file (default: active file). The file extension is preserved automatically if omitted from the new name. Use
file=<name> # file name
path=<path> # file path
name=<name> # (required) new file name
#
delete
Delete a file (default: active file, trash by default).
file=<name> # file name
path=<path> # file path
permanent # skip trash, delete permanently
#
Links
Commands for Backlinks and Outgoing links.
#
backlinks
List backlinks to a file (default: active file).
file=<name> # target file name
path=<path> # target file path
counts # include link counts
total # return backlink count
format=json|tsv|csv # output format (default: tsv)
#
links
List outgoing links from a file (default: active file).
file=<name> # file name
path=<path> # file path
total # return link count
#
unresolved
List unresolved links in vault.
total # return unresolved link count
counts # include link counts
verbose # include source files
format=json|tsv|csv # output format (default: tsv)
#
orphans
List files with no incoming links.
total # return orphan count
#
deadends
List files with no outgoing links.
total # return dead-end count
#
Outline
Commands for Outline.
#
outline
Show headings for the current file.
file=<name> # file name
path=<path> # file path
format=tree|md|json # output format (default: tree)
total # return heading count
#
Plugins
Commands for Core plugins and Community plugins.
#
plugins
List installed plugins.
filter=core|community # filter by plugin type
versions # include version numbers
format=json|tsv|csv # output format (default: tsv)
#
plugins:enabled
List enabled plugins.
filter=core|community # filter by plugin type
versions # include version numbers
format=json|tsv|csv # output format (default: tsv)
#
plugins:restrict
Toggle or check restricted mode.
on # enable restricted mode
off # disable restricted mode
#
plugin
Get plugin info.
id=<plugin-id> # (required) plugin ID
#
plugin:enable
Enable a plugin.
id=<id> # (required) plugin ID
filter=core|community # plugin type
#
plugin:disable
Disable a plugin.
id=<id> # (required) plugin ID
filter=core|community # plugin type
#
plugin:install
Install a community plugin.
id=<id> # (required) plugin ID
enable # enable after install
#
plugin:uninstall
Uninstall a community plugin.
id=<id> # (required) plugin ID
#
plugin:reload
Reload a plugin (for developers).
id=<id> # (required) plugin ID
#
Properties
Commands related to Properties.
#
aliases
List aliases in the vault. Use active or file/path to show aliases for a specific file.
file=<name> # file name
path=<path> # file path
total # return alias count
verbose # include file paths
active # show aliases for active file
#
properties
List properties in the vault. Use active or file/path to show properties for a specific file.
file=<name> # show properties for file
path=<path> # show properties for path
name=<name> # get specific property count
sort=count # sort by count (default: name)
format=yaml|json|tsv # output format (default: yaml)
total # return property count
counts # include occurrence counts
active # show properties for active file
#
property:set
Set a property on a file (default: active file).
name=<name> # (required) property name
value=<value> # (required) property value
type=text|list|number|checkbox|date|datetime # property type
file=<name> # file name
path=<path> # file path
#
property:remove
Remove a property from a file (default: active file).
name=<name> # (required) property name
file=<name> # file name
path=<path> # file path
#
property:read
Read a property value from a file (default: active file).
name=<name> # (required) property name
file=<name> # file name
path=<path> # file path
#
Publish
Commands for Obsidian Publish.
#
publish:site
Show publish site info (slug, URL).
#
publish:list
List published files.
total # return published file count
#
publish:status
List publish changes.
total # return change count
new # show new files only
changed # show changed files only
deleted # show deleted files only
#
publish:add
Publish a file or all changed files (default: active file).
file=<name> # file name
path=<path> # file path
changed # publish all changed files
#
publish:remove
Unpublish a file (default: active file).
file=<name> # file name
path=<path> # file path
#
publish:open
Open file on published site (default: active file).
file=<name> # file name
path=<path> # file path
#
Random notes
Commands for Random note.
#
random
Open a random note.
folder=<path> # limit to folder
newtab # open in new tab
#
random:read
Read a random note (includes path).
folder=<path> # limit to folder
#
Search
Commands for Search.
#
search
Search vault for text. Returns matching file paths.
query=<text> # (required) search query
path=<folder> # limit to folder
limit=<n> # max files
format=text|json # output format (default: text)
total # return match count
case # case sensitive
#
search:context
Search with matching line context. Returns grep-style path:line: text output.
query=<text> # (required) search query
path=<folder> # limit to folder
limit=<n> # max files
format=text|json # output format (default: text)
case # case sensitive
#
search:open
Open search view.
query=<text> # initial search query
#
Sync
Commands for Obsidian Sync.
#
sync
Pause or resume sync.
on # resume sync
off # pause sync
#
sync:status
Show sync status and usage.
#
sync:history
List sync version history for a file (default: active file).
file=<name> # file name
path=<path> # file path
total # return version count
#
sync:read
Read a sync version (default: active file).
file=<name> # file name
path=<path> # file path
version=<n> # (required) version number
#
sync:restore
Restore a sync version (default: active file).
file=<name> # file name
path=<path> # file path
version=<n> # (required) version number
#
sync:open
Open sync history (default: active file).
file=<name> # file name
path=<path> # file path
#
sync:deleted
List deleted files in sync.
total # return deleted file count
#
Tags
Commands for Tags.
#
tags
List tags in the vault. Use active or file/path to show tags for a specific file.
file=<name> # file name
path=<path> # file path
sort=count # sort by count (default: name)
total # return tag count
counts # include tag counts
format=json|tsv|csv # output format (default: tsv)
active # show tags for active file
#
tag
Get tag info.
name=<tag> # (required) tag name
total # return occurrence count
verbose # include file list and count
#
Tasks
Commands for task management.
#
tasks
List tasks in the vault. Use active or file/path to show tasks for a specific file.
file=<name> # filter by file name
path=<path> # filter by file path
status="<char>" # filter by status character
total # return task count
done # show completed tasks
todo # show incomplete tasks
verbose # group by file with line numbers
format=json|tsv|csv # output format (default: text)
active # show tasks for active file
daily # show tasks from daily note
Examples:
# List all tasks in the vault
tasks
# List incomplete tasks in the vault
tasks todo
# List completed tasks from a specific file
tasks file=Recipe done
# List tasks from today's daily note
tasks daily
# Count tasks in daily note
tasks daily total
# List tasks with file paths and line numbers
tasks verbose
# Filter by custom status (quote special chars)
tasks 'status=?'
#
task
Show or update a task.
ref=<path:line> # task reference (path:line)
file=<name> # file name
path=<path> # file path
line=<n> # line number
status="<char>" # set status character
toggle # toggle task status
daily # daily note
done # mark as done
todo # mark as todo
Examples:
# Show task info
task file=Recipe line=8
task ref="Recipe.md:8"
# Toggle task completion
task ref="Recipe.md:8" toggle
# Toggle task in daily note
task daily line=3 toggle
# Set task status
task file=Recipe line=8 done # → [x]
task file=Recipe line=8 todo # → [ ]
task file=Recipe line=8 status=- # → [-]
task daily line=3 done # Mark daily note task as done
#
Templates
Commands for Templates.
#
templates
List templates.
total # return template count
#
template:read
Read template content.
name=<template> # (required) template name
title=<title> # title for variable resolution
resolve # resolve template variables
#
template:insert
Insert template into active file.
name=<template> # (required) template name
Notes:
resolveoption processes{{date}},{{time}},{{title}}variables- Use
create path=<path> template=<name>to create a file with a template
#
Themes and snippets
Commands for Themes and CSS snippets.
#
themes
List installed themes.
versions # include version numbers
#
theme
Show active theme or get info.
name=<name> # theme name for details
#
theme:set
Set active theme.
name=<name> # (required) theme name (empty for default)
#
theme:install
Install a community theme.
name=<name> # (required) theme name
enable # activate after install
#
theme:uninstall
Uninstall a theme.
name=<name> # (required) theme name
#
snippets
List installed CSS snippets.
#
snippets:enabled
List enabled CSS snippets.
#
snippet:enable
Enable a CSS snippet.
name=<name> # (required) snippet name
#
snippet:disable
Disable a CSS snippet.
name=<name> # (required) snippet name
#
Unique notes
Commands for Unique note creator.
#
unique
Create unique note.
name=<text> # note name
content=<text> # initial content
paneType=tab|split|window # pane type to open in
open # open file after creating
#
Vault
#
vault
Show vault info.
info=name|path|files|folders|size # return specific info only
#
vaults
List known vaults.
total # return vault count
verbose # include vault paths
#
vault:open
Switch to a different vault (TUI only).
name=<name> # (required) vault name
#
Web viewer
Commands for Web viewer.
#
web
Open URL in web viewer.
url=<url> # (required) URL to open
newtab # open in new tab
#
Wordcount
Commands for Word count.
#
wordcount
Count words and characters (default: active file).
file=<name> # file name
path=<path> # file path
words # return word count only
characters # return character count only
#
Workspace
Commands for Workspace and the Workspaces plugin.
#
workspace
Show workspace tree.
ids # include workspace item IDs
#
workspaces
List saved workspaces.
total # return workspace count
#
workspace:save
Save current layout as workspace.
name=<name> # workspace name
#
workspace:load
Load a saved workspace.
name=<name> # (required) workspace name
#
workspace:delete
Delete a saved workspace.
name=<name> # (required) workspace name
#
tabs
List open tabs.
ids # include tab IDs
#
tab:open
Open a new tab.
group=<id> # tab group ID
file=<path> # file to open
view=<type> # view type to open
#
recents
List recently opened files.
total # return recent file count
#
Developer commands
Commands to help you develop Community plugins and Themes. Learn more by heading to the Obsidian Developer Documentation.
#
devtools
Toggle Electron dev tools.
#
dev:debug
Attach/detach Chrome DevTools Protocol debugger.
on # attach debugger
off # detach debugger
#
dev:cdp
Run a Chrome DevTools Protocol command.
method=<CDP.method> # (required) CDP method to call
params=<json> # method parameters as JSON
#
dev:errors
Show captured JavaScript errors.
clear # clear the error buffer
#
dev:screenshot
Take a screenshot (returns base64 PNG).
path=<filename> # output file path
#
dev:console
Show captured console messages.
limit=<n> # max messages to show (default 50)
level=log|warn|error|info|debug # filter by log level
clear # clear the console buffer
#
dev:css
Inspect CSS with source locations.
selector=<css> # (required) CSS selector
prop=<name> # filter by property name
#
dev:dom
Query DOM elements.
selector=<css> # (required) CSS selector
attr=<name> # get attribute value
css=<prop> # get CSS property value
total # return element count
text # return text content
inner # return innerHTML instead of outerHTML
all # return all matches instead of first
#
dev:mobile
Toggle mobile emulation.
on # enable mobile emulation
off # disable mobile emulation
#
eval
Execute JavaScript and return result.
code=<javascript> # (required) JavaScript code to execute
#
Keyboard shortcuts
These shortcuts are available in the
#
Navigation
#
Editing
#
Autocomplete
#
History
#
Other
#
Troubleshooting
If you are having trouble running Obsidian CLI:
- Make sure you are using the latest Obsidian installer version (1.11.7) and the latest early access version (1.12).
- Restart your terminal after registering the CLI for the PATH changes to take effect.
- Obsidian must be running. The CLI connects to the running Obsidian instance. If Obsidian is not running, the first CLI command should launch the app.
#
Windows
Windows requires using a terminal redirector that connects to Obsidian to stdin/stdout properly. This is unfortunately necessary because Obsidian normally runs as a GUI app which is incompatible with terminal outputs.
To get this file, go to the official Obsidian Discord in the #insider-desktop-release channel. Requires a Catalyst license.
- Download the
Obsidian.comfile here. - Place the
Obsidian.comfile in the folder where you installed theObsidian.exefile, which could be one of these paths:C:\Users\<YourUsername>\AppData\Local\Programs\obsidian\C:\Users\<YourUsername>\AppData\Local\obsidian\
#
macOS
The CLI registration adds the Obsidian binary directory to your PATH via ~/.zprofile. If you are having trouble, check the following:
Your ~/.zprofile file should contain the following line. If it's missing, you can add it manually:
export PATH="$PATH:/Applications/Obsidian.app/Contents/MacOS"
#
Alternate shells
The CLI registration only modifies ~/.zprofile, which is used by zsh (the default macOS shell). If you use a different shell, add the Obsidian binary directory to your shell's configuration file manually:
- Bash: add
export PATH="$PATH:/Applications/Obsidian.app/Contents/MacOS"to~/.bash_profile - Fish: run
fish_add_path /Applications/Obsidian.app/Contents/MacOS
#
Linux
The CLI registration creates a symlink at /usr/local/bin/obsidian pointing to the Obsidian binary (requires sudo).
#
AppImage
For AppImage installs, the symlink points to the .AppImage file instead of the internal binary, since the mount path changes each launch. If sudo fails, the symlink is created at ~/.local/bin/obsidian as a fallback. If you are having trouble, check the following.
Check that the symlink exists and points to the correct binary:
ls -l /usr/local/bin/obsidian
If the symlink is missing, create it manually:
sudo ln -s /path/to/obsidian /usr/local/bin/obsidian
I the symlink was created in ~/.local/bin/ instead, make sure that directory is in your PATH. Add the following to your ~/.bashrc or ~/.zshrc:
export PATH="$PATH:$HOME/.local/bin"
If the symlink breaks after moving or renaming the .AppImage file, re-register the CLI or update the symlink manually.
#
Snap
The Snap package stores insider build data in its own user data directory. If the CLI doesn't detect the insider .asar, set XDG_CONFIG_HOME to point to the Snap config path:
export XDG_CONFIG_HOME="$HOME/snap/obsidian/current/.config"
Add this to your ~/.bashrc or ~/.zshrc to make it persistent.
#
Flatpak
Obsidian tries to do this automatically, but below are the manual instructions. If it is a system install:
ln -s /var/lib/flatpak/exports/bin/md.obsidian.Obsidian ~/.local/bin/obsidian
If it is a user install:
ln -s ~/.local/share/flatpak/exports/bin/md.obsidian.Obsidian ~/.local/bin/obsidian