Vim Cheat Sheet
-
Global
- :h[elp] keyword – open help for keyword
- :sav[eas] file – save file as
- :clo[se] – close current pane
- :ter[minal] – open a terminal window
- K – open man page for word under the cursor
Tip Run vimtutor in a terminal to learn the first Vim commands.
Cursor movement
- h – move cursor left
- j – move cursor down
- k – move cursor up
- l – move cursor right
- gj – move cursor down (multi-line text)
- gk – move cursor up (multi-line text)
- H – move to top of screen
- M – move to middle of screen
- L – move to bottom of screen
- w – jump forwards to the start of a word
- W – jump forwards to the start of a word (words can contain punctuation)
- e – jump forwards to the end of a word
- E – jump forwards to the end of a word (words can contain punctuation)
- b – jump backwards to the start of a word
- B – jump backwards to the start of a word (words can contain punctuation)
- ge – jump backwards to the end of a word
- gE – jump backwards to the end of a word (words can contain punctuation)
- % – move cursor to matching character (default supported pairs: ‘()’, ‘{}’, ‘[]’ – use
:h matchpairs
in vim for more info) - 0 – jump to the start of the line
- ^ – jump to the first non-blank character of the line
- $ – jump to the end of the line
- g_ – jump to the last non-blank character of the line
- gg – go to the first line of the document
- G – go to the last line of the document
- 5gg or 5G – go to line 5
- gd – move to local declaration
- gD – move to global declaration
- fx – jump to next occurrence of character x
- tx – jump to before next occurrence of character x
- Fx – jump to the previous occurrence of character x
- Tx – jump to after previous occurrence of character x
- ; – repeat previous f, t, F or T movement
- , – repeat previous f, t, F or T movement, backwards
- } – jump to next paragraph (or function/block, when editing code)
- { – jump to previous paragraph (or function/block, when editing code)
- zz – center cursor on screen
- zt – position cursor on top of the screen
- zb – position cursor on bottom of the screen
- Ctrl + e – move screen down one line (without moving cursor)
- Ctrl + y – move screen up one line (without moving cursor)
- Ctrl + b – move screen up one page (cursor to last line)
- Ctrl + f – move screen down one page (cursor to first line)
- Ctrl + d – move cursor and screen down 1/2 page
- Ctrl + u – move cursor and screen up 1/2 page
Tip Prefix a cursor movement command with a number to repeat it. For example, 4j moves down 4 lines.
Insert mode – inserting/appending text
- i – insert before the cursor
- I – insert at the beginning of the line
- a – insert (append) after the cursor
- A – insert (append) at the end of the line
- o – append (open) a new line below the current line
- O – append (open) a new line above the current line
- ea – insert (append) at the end of the word
- Ctrl + h – delete the character before the cursor during insert mode
- Ctrl + w – delete word before the cursor during insert mode
- Ctrl + j – add a line break at the cursor position during insert mode
- Ctrl + t – indent (move right) line one shiftwidth during insert mode
- Ctrl + d – de-indent (move left) line one shiftwidth during insert mode
- Ctrl + n – insert (auto-complete) next match before the cursor during insert mode
- Ctrl + p – insert (auto-complete) previous match before the cursor during insert mode
- Ctrl + rx – insert the contents of register x
- Ctrl + ox – Temporarily enter normal mode to issue one normal-mode command x.
- Esc or Ctrl + c – exit insert mode
Editing
- r – replace a single character.
- R – replace more than one character, until ESC is pressed.
- J – join line below to the current one with one space in between
- gJ – join line below to the current one without space in between
- gwip – reflow paragraph
- g~ – switch case up to motion
- gu – change to lowercase up to motion
- gU – change to uppercase up to motion
- cc – change (replace) entire line
- c$ or C – change (replace) to the end of the line
- ciw – change (replace) entire word
- cw or ce – change (replace) to the end of the word
- s – delete character and substitute text
- S – delete line and substitute text (same as cc)
- xp – transpose two letters (delete and paste)
- u – undo
- U – restore (undo) last changed line
- Ctrl + r – redo
- . – repeat last command
Marking text (visual mode)
- v – start visual mode, mark lines, then do a command (like y-yank)
- V – start linewise visual mode
- o – move to other end of marked area
- Ctrl + v – start visual block mode
- O – move to other corner of block
- aw – mark a word
- ab – a block with ()
- aB – a block with {}
- at – a block with <> tags
- ib – inner block with ()
- iB – inner block with {}
- it – inner block with <> tags
- Esc or Ctrl + c – exit visual mode
Tip Instead of b or B one can also use ( or { respectively.
Visual commands
-
– shift text right
- < – shift text left
- y – yank (copy) marked text
- d – delete marked text
- ~ – switch case
- u – change marked text to lowercase
- U – change marked text to uppercase
Registers
- :reg[isters] – show registers content
- "xy – yank into register x
- "xp – paste contents of register x
- "+y – yank into the system clipboard register
- "+p – paste from the system clipboard register
Tip Registers are being stored in ~/.viminfo, and will be loaded again on next restart of vim.
Tip Special registers:
0 – last yank
" – unnamed register, last delete or yank
% – current file name
# – alternate file name
* – clipboard contents (X11 primary)
+ – clipboard contents (X11 clipboard)
/ – last search pattern
: – last command-line
. – last inserted text
- – last small (less than a line) delete
= – expression register
_ – black hole registerMarks and positions
- :marks – list of marks
- ma – set current position for mark A
- `a – jump to position of mark A
- y`a – yank text to position of mark A
- `0 – go to the position where Vim was previously exited
- `" – go to the position when last editing this file
- `. – go to the position of the last change in this file
- `` – go to the position before the last jump
- :ju[mps] – list of jumps
- Ctrl + i – go to newer position in jump list
- Ctrl + o – go to older position in jump list
- :changes – list of changes
- g, – go to newer position in change list
- g; – go to older position in change list
- Ctrl + ] – jump to the tag under cursor
Tip To jump to a mark you can either use a backtick (`) or an apostrophe ('). Using an apostrophe jumps to the beginning (first non-blank) of the line holding the mark.
Macros
- qa – record macro a
- q – stop recording macro
- @a – run macro a
- @@ – rerun last run macro
Cut and paste
- yy – yank (copy) a line
- 2yy – yank (copy) 2 lines
- yw – yank (copy) the characters of the word from the cursor position to the start of the next word
- yiw – yank (copy) word under the cursor
- yaw – yank (copy) word under the cursor and the space after or before it
- y$ or Y – yank (copy) to end of line
- p – put (paste) the clipboard after cursor
- P – put (paste) before cursor
- gp – put (paste) the clipboard after cursor and leave cursor after the new text
- gP – put (paste) before cursor and leave cursor after the new text
- dd – delete (cut) a line
- 2dd – delete (cut) 2 lines
- dw – delete (cut) the characters of the word from the cursor position to the start of the next word
- diw – delete (cut) word under the cursor
- daw – delete (cut) word under the cursor and the space after or before it
- :3,5d – delete lines starting from 3 to 5
- :g/{pattern}/d – delete all lines containing pattern
- :g!/{pattern}/d – delete all lines not containing pattern
- d$ or D – delete (cut) to the end of the line
- x – delete (cut) character
Indent text
-
– indent (move right) line one shiftwidth
- << – de-indent (move left) line one shiftwidth
-
% – indent a block with () or {} (cursor on brace)
- <% – de-indent a block with () or {} (cursor on brace)
-
ib – indent inner block with ()
-
at – indent a block with <> tags
- 3== – re-indent 3 lines
- =% – re-indent a block with () or {} (cursor on brace)
- =iB – re-indent inner block with {}
- gg=G – re-indent entire buffer
- ]p – paste and adjust indent to current line
Exiting
- :w – write (save) the file, but don’t exit
- :w !sudo tee % – write out the current file using sudo
- :wq or ![:@] or ZZ – write (save) and quit
- :q – quit (fails if there are unsaved changes)
- :q! or ZQ – quit and throw away unsaved changes
- :wqa – write (save) and quit on all tabs
Search and replace
- /pattern – search for pattern
- ?pattern – search backward for pattern
- \vpattern – ‘very magic’ pattern: non-alphanumeric characters are interpreted as special regex symbols (no escaping needed)
- n – repeat search in same direction
- N – repeat search in opposite direction
- :%s/old/new/g – replace all old with new throughout file
- :%s/old/new/gc – replace all old with new throughout file with confirmations
- :noh[lsearch] – remove highlighting of search matches
Search in multiple files
- :vim[grep] /pattern/ {
{file}
} – search for pattern in multiple files
e.g. :vim[grep] /foo/ */
- :cn[ext] – jump to the next match
- :cp[revious] – jump to the previous match
- :cope[n] – open a window containing the list of matches
- :ccl[ose] – close the quickfix window
Tabs
- :tabnew or :tabnew {page.words.file} – open a file in a new tab
- Ctrl + wT – move the current split window into its own tab
- gt or :tabn[ext] – move to the next tab
- gT or :tabp[revious] – move to the previous tab
- #gt – move to tab number #
- :tabm[ove] # – move current tab to the #th position (indexed from 0)
- :tabc[lose] – close the current tab and all its windows
- :tabo[nly] – close all tabs except for the current one
- :tabdo command – run the
command
on all tabs (e.g.:tabdo q
– closes all opened tabs)
Working with multiple files
- :e[dit] file – edit a file in a new buffer
- :bn[ext] – go to the next buffer
- :bp[revious] – go to the previous buffer
- :bd[elete] – delete a buffer (close a file)
- :b[uffer]# – go to a buffer by index #
- :b[uffer] file – go to a buffer by file
- :ls or :buffers – list all open buffers
- :sp[lit] file – open a file in a new buffer and split window
- :vs[plit] file – open a file in a new buffer and vertically split window
- :vert[ical] ba[ll] – edit all buffers as vertical windows
- :tab ba[ll] – edit all buffers as tabs
- Ctrl + ws – split window
- Ctrl + wv – split window vertically
- Ctrl + ww – switch windows
- Ctrl + wq – quit a window
- Ctrl + wx – exchange current window with next one
- Ctrl + w= – make all windows equal height & width
- Ctrl + wh – move cursor to the left window (vertical split)
- Ctrl + wl – move cursor to the right window (vertical split)
- Ctrl + wj – move cursor to the window below (horizontal split)
- Ctrl + wk – move cursor to the window above (horizontal split)
- Ctrl + wH – make current window full height at far left (leftmost vertical window)
- Ctrl + wL – make current window full height at far right (rightmost vertical window)
- Ctrl + wJ – make current window full width at the very bottom (bottommost horizontal window)
- Ctrl + wK – make current window full width at the very top (topmost horizontal window)