- Vim cheat sheet. GitHub Gist: instantly share code, notes, and snippets.
- About the vim cheat sheet. This project aims to be one of the most accessible vim guides available. We made sure to support mobile, desktop, and other languages. ️ Please consider sponsoring this project ️!
- Navigation - Word. End of current word. Can use caps to use S instead of w as boundary. Download the Vim Cheat.
- 150 Cheat Sheets tagged with Vim. Magic; Rating; Newest; Oldest; Name; Downloads; Views.
How to Exit
I made a vim navigation cheatsheet hello everyone, i use vim for 5 days and i am a beginner on it, my main goal for it was to completely use the keyboard and never use the mouse but navigating for me was pretty confusing. So i search the internet for lots of navigation commands and compile it into one txt file.

:q[uit] | Quit Vim. This fails when changes have been made. |
:q[uit]! | Quit without writing. |
:cq[uit] | Quit always, without writing. |
:wq | Write the current file and exit. |
:wq! | Write the current file and exit always. |
:wq {file} | Write to {file}. Exit if not editing the last |
:wq! {file} | Write to {file} and exit always. |
:[range]wq[!] | [file] Same as above, but only write the lines in [range]. |
ZZ | Write current file, if modified, and exit. |
ZQ | Quit current file and exit (same as ':q!'). |
Editing a File
:e[dit] | Edit the current file. This is useful to re-edit the current file, when it has been changed outside of Vim. |
:e[dit]! | Edit the current file always. Discard any changes to the current buffer. This is useful if you want to start all over again. |
:e[dit] {file} | Edit {file}. |
:e[dit]! {file} | Edit {file} always. Discard any changes to the current buffer. |
gf | Edit the file whose name is under or after the cursor. Mnemonic: 'goto file'. |
Inserting Text
a | Append text after the cursor [count] times. |
A | Append text at the end of the line [count] times. |
i | Insert text before the cursor [count] times. |
I | Insert text before the first non-blank in the line [count] times. |
gI | Insert text in column 1 [count] times. |
o | Begin a new line below the cursor and insert text, repeat [count] times. |
O | Begin a new line above the cursor and insert text, repeat [count] times. |
Inserting a file
:r[ead] [name] | Insert the file [name] below the cursor. |
:r[ead] !{cmd} | Execute {cmd} and insert its standard output below the cursor. |
Deleting Text
<Del> or x | Delete [count] characters under and after the cursor |
X | Delete [count] characters before the cursor |
d{motion} | Delete text that {motion} moves over |
dd | Delete [count] lines |
D | Delete the characters under the cursor until the end of the line |
{Visual}x or {Visual}d | Delete the highlighted text (for {Visual} see Selecting Text). |
{Visual}CTRL-H or {Visual} | When in Select mode: Delete the highlighted text |
{Visual}X or {Visual}D | Delete the highlighted lines |
:[range]d[elete] | Delete [range] lines (default: current line) |
:[range]d[elete] {count} | Delete {count} lines, starting with [range] |
Changing (or Replacing) Text

r{char} | replace the character under the cursor with {char}. |
R | Enter Insert mode, replacing characters rather than inserting |
~ | Switch case of the character under the cursor and move the cursor to the right. If a [count] is given, do that many characters. |
~{motion} | switch case of {motion} text. |
{Visual}~ | Switch case of highlighted text |
Substituting
:[range]s[ubstitute]/{pattern}/{string}/[c][e][g][p][r][i][I] [count] | For each line in [range] replace a match of {pattern} with {string}. |
:[range]s[ubstitute] [c][e][g][r][i][I] [count] :[range]&[c][e][g][r][i][I] [count] | Repeat last :substitute with same search pattern and substitute string, but without the same flags. You may add extra flags |

Copying and Moving Text

'{a-zA-Z0-9.%#:-'} | Use register {a-zA-Z0-9.%#:-'} for next delete, yank or put (use uppercase character to append with delete and yank) ({.%#:} only work with put). |
:reg[isters] | Display the contents of all numbered and named registers. |
:reg[isters] {arg} | Display the contents of the numbered and named registers that are mentioned in {arg}. |
:di[splay] [arg] | Same as :registers. |
['x]y{motion} | Yank {motion} text [into register x]. |
['x]yy | Yank [count] lines [into register x] |
['x]Y | yank [count] lines [into register x] (synonym for yy). |
{Visual}['x]y | Yank the highlighted text [into register x] (for {Visual} see Selecting Text). |
{Visual}['x]Y | Yank the highlighted lines [into register x] |
:[range]y[ank] [x] | Yank [range] lines [into register x]. |
:[range]y[ank] [x] {count} | Yank {count} lines, starting with last line number in [range] (default: current line), [into register x]. |
['x]p | Put the text [from register x] after the cursor [count] times. |
['x]P | Put the text [from register x] before the cursor [count] times. |
['x]gp | Just like 'p', but leave the cursor just after the new text. |
['x]gP | Just like 'P', but leave the cursor just after the new text. |
:[line]pu[t] [x] | Put the text [from register x] after [line] (default current line). |
:[line]pu[t]! [x] | Put the text [from register x] before [line] (default current line). |
Undo/Redo/Repeat
u | Undo [count] changes. |
:u[ndo] | Undo one change. |
CTRL-R | Redo [count] changes which were undone. |
:red[o] | Redo one change which was undone. |
U | Undo all latest changes on one line. {Vi: while not moved off of it} |
. | Repeat last change, with count replaced with [count]. |
Moving Around
h or | [count] characters to the left (exclusive). |
l or | [count] characters to the right (exclusive). |
k or CTRL-P | [count] lines upward |
j or CTRL-J or CTRL-N | [count] lines downward (linewise). |
0 | To the first character of the line (exclusive). |
<Home> | To the first character of the line (exclusive). |
^ | To the first non-blank character of the line |
$ or <End> | To the end of the line and [count - 1] lines downward |
g0 or g<Home> | When lines wrap ('wrap on): To the first character of the screen line (exclusive). Differs from '0' when a line is wider than the screen. When lines don't wrap ('wrap' off): To the leftmost character of the current line that is on the screen. Differs from '0' when the first character of the line is not on the screen. |
g^ | When lines wrap ('wrap' on): To the first non-blank character of the screen line (exclusive). Differs from '^' when a line is wider than the screen. When lines don't wrap ('wrap' off): To the leftmost non-blank character of the current line that is on the screen. Differs from '^' when the first non-blank character of the line is not on the screen. |
g$ or g<End&gr; | When lines wrap ('wrap' on): To the last character of the screen line and [count - 1] screen lines downward (inclusive). Differs from '$' when a line is wider than the screen. When lines don't wrap ('wrap' off): To the rightmost character of the current line that is visible on the screen. Differs from '$' when the last character of the line is not on the screen or when a count is used. |
f{char} | To [count]'th occurrence of {char} to the right. The cursor is placed on {char} (inclusive). |
F{char} | To the [count]'th occurrence of {char} to the left. The cursor is placed on {char} (inclusive). |
t{char} | Till before [count]'th occurrence of {char} to the right. The cursor is placed on the character left of {char} (inclusive). |
T{char} | Till after [count]'th occurrence of {char} to the left. The cursor is placed on the character right of {char} (inclusive). |
; | Repeat latest f, t, F or T [count] times. |
, | Repeat latest f, t, F or T in opposite direction [count] times. |
- <minus> | [count] lines upward, on the first non-blank character (linewise). |
+ or CTRL-M or <CR> | [count] lines downward, on the first non-blank character (linewise). |
_ <underscore> | [count] - 1 lines downward, on the first non-blank character (linewise). |
<C-End> or G | Goto line [count], default last line, on the first non-blank character. |
<C-Home> or gg | Goto line [count], default first line, on the first non-blank character. |
<S-Right> or w | [count] words forward |
<C-Right> or W | [count] WORDS forward |
e | Forward to the end of word [count] |
E | Forward to the end of WORD [count] |
<S-Left> or b | [count] words backward |
<C-Left> or B | [count] WORDS backward |
ge | Backward to the end of word [count] |
gE | Backward to the end of WORD [count] |
A word consists of a sequence of letters, digits and underscores, or asequence of other non-blank characters, separated with white space (spaces,tabs,
A WORD consists of a sequence of non-blank characters, separated with whitespace. An empty line is also considered to be a word and a WORD.
( | [count] sentences backward |
) | [count] sentences forward |
{ | [count] paragraphs backward |
} | [count] paragraphs forward |
]] | [count] sections forward or to the next '{' in the first column. When used after an operator, then the '}' in the first column. |
][ | [count] sections forward or to the next '}' in the first column |
[[ | [count] sections backward or to the previous '{' in the first column |
[] | [count] sections backward or to the previous '}' in the first column |
Screen movement commands
z. | Center the screen on the cursor |
zt | Scroll the screen so the cursor is at the top |
zb | Scroll the screen so the cursor is at the bottom |
Marks
m{a-zA-Z} | Set mark {a-zA-Z} at cursor position (does not move the cursor, this is not a motion command). |
m' or m` | Set the previous context mark. This can be jumped to with the '' or '``' command (does not move the cursor, this is not a motion command). |
:[range]ma[rk] {a-zA-Z} | Set mark {a-zA-Z} at last line number in [range], column 0. Default is cursor line. |
:[range]k{a-zA-Z} | Same as :mark, but the space before the mark name can be omitted. |
'{a-z} | To the first non-blank character on the line with mark {a-z} (linewise). |
'{A-Z0-9} | To the first non-blank character on the line with mark {A-Z0-9} in the correct file |
`{a-z} | To the mark {a-z} |
`{A-Z0-9} | To the mark {A-Z0-9} in the correct file |
:marks | List all the current marks (not a motion command). |
:marks {arg} | List the marks that are mentioned in {arg} (not a motion command). For example: |
Searching
/{pattern}[/] | Search forward for the [count]'th occurrence of {pattern} |
/{pattern}/{offset} | Search forward for the [count]'th occurrence of {pattern} and go {offset} lines up or down. |
/<CR> | Search forward for the [count]'th latest used pattern |
//{offset}<CR> | Search forward for the [count]'th latest used pattern with new. If {offset} is empty no offset is used. |
?{pattern}[?]<CR> | Search backward for the [count]'th previous occurrence of {pattern} |
?{pattern}?{offset}<CR> | Search backward for the [count]'th previous occurrence of {pattern} and go {offset} lines up or down |
?<CR> | Search backward for the [count]'th latest used pattern |
??{offset}<CR> | Search backward for the [count]'th latest used pattern with new {offset}. If {offset} is empty no offset is used. |
n | Repeat the latest '/' or '?' [count] times. |
N | Repeat the latest '/' or '?' [count] times in opposite direction. |

Selecting Text (Visual Mode)
To select text, enter visual mode with one of the commands below, and usemotion commands to highlight the text you are interestedin. Then, use some command on the text.
v | start Visual mode per character. |
V | start Visual mode linewise. |
<Esc> | exit Visual mode without making any changes |
How to Suspend
CTRL-Z | Suspend Vim, like ':stop'. Works in Normal and in Visual mode. In Insert and Command-line mode, the CTRL-Z is inserted as a normal character. |
:sus[pend][!] or :st[op][!] | Suspend Vim. If the '!' is not given and 'autowrite' is set, every buffer with changes and a file name is written out. If the '!' is given or 'autowrite' is not set, changed buffers are not written, don't forget to bring Vim back to the foreground later! |
For a long time, I ran away from Vim because it seemed very tricky and because there is a lot of simpler editors out there to work with. However, as it comes installed in most Linux distributions, I made this cheat sheet to help me understand how things work. I have discovered that is possible to be very productive with Vim 😃.
I’ll try to go straight to the point. This cheat-sheet is not intended to be a complete guide but it helps to get started.
Vim have different operation modes, and I will not cover all of them in this cheat sheet. I’ll stick with the basic functionality needed to open, edit and save a file.
Let’s begin! To open a file with Vim just type vim filename
.ESC
= enter “command mode”
Move the cursor
You can use the arrow keys to move the cursor around. There is also special keys to do this:
h
= move one character leftj
= move one row downk
= move one row upl
= move one character right
Vim Cheat Pdf
Edition Mode
The following keys have to be typed in “Command Mode”.
i
= insert text in the cursor positionI
= insert text in the begin of the lineo
= insert text in the next lineO
= insert text in the previous linea
= insert a character after the currentA
= insert text at the end of the liner
= replace the character at the current cursor positionR
= enter replace mode to replace characters from the current cursor positionu
= undo last actionCTRL + r
= redo
Saving & Exiting
The following keys have to be typed in “Command Mode”.
:w
= Save:q
= Exit:q!
= Force exit (exit without saving):qa
= Exit from all opened files:wq
= Save and exit:x
= Save and exitZZ
= Save and exitZQ
= Force exit (exit without saving)
Copy, paste & cut
The following keys have to be typed in “Command Mode”.
yy
= copy linep
= paste content to the below lineP
= paste content to the above lineyNy
= copy N linescw
= cut the word starting from the current cursor positiondd
= cut or delete a lineD
= delete the line starting from the current cursor positiondG
= delete the lines starting from the current cursor position to the end of the filedGG
= delete the lines starting from the current cursor position to the begin of the filedw
= delete the word starting from the current cursor positiondNd
= cut or delete N linesx
= delete a character at the current cursor position (similar to “delete” key behaviour)X
= delete a character before the current cursor position (similar to “backspace” key behaviour)yw
= copy the word starting from the current cursor position
Printable Vim Cheat Sheet Pdf
Visual Mode
The following keys have to be typed in “Command Mode”.
v
= visual mode that allows to select a text fragmentV
= visual mode that allows to select an entire lineCTRL+v
= visual block that allows select a block of text
Navigation
The following keys have to be typed in “Command Mode”.
/pattern
= search forward for a patter?pattern
= search backward for a patternn
= pattern forward searchN
= pattern backward searchgg
= goes to the first line of the fileG
= goes to the last line of the fileH
= goes to the top of the current screenM
= goes to the middle of the current screenL
= goes to the end of the current screen
Commands
Vim Cheat Sheet For Programmer
The following keys have to be typed in “Command Mode”.
:set hlsearch
= enable search highlight:set number
= show line numbers:set tabstop=N
= set the size of TAB to N:set expandtab
= convert TAB in spaces:set bg=dark/light
= change the color scheme:set ignorecase
= makes the search case insensitive:syntax on/off
= enable/disable syntax highlighting:LNs/tobereplaced/replacer/g
= replaces(s) all(g) tobereplaced with replacer in the line LN:%s/tobereplaced/replacer/g
= replaces(s) all(g) tobereplaced with replacer in the entire file:e filename
= opens “filename”:r filename
= copy the contents of the “filename” to the current file:split filename
= split screen horizontally to show the current file and “filename”:vsplit filename
= split screen vertically to show the current file and “filename”:! command
= runs “command” in shell and show the STDOUT!! command
= runs “command” in shell and paste the STDOUT in the file
