This is an old revision of the document!
Table of Contents
VIM
There's an old joke that Emacs would be a great operating system if only it had a decent text editor,
whereas vi would be a great text editor if only it had a decent operating system.
File Cleaning
Remove Blank line from the file
to remove blank lines please use following.
:g/^$/d
OR
:g/^ *$/d
Remove Tailing space as well space at beginning using VI
To remove tailing space
:%s/\s\+$//
To remove space at beginning
:%s/^\s\+//
Replace tab with space
To replace tab with space you need to use
:%s/[CTRL-i]/ /g
Delete Line start with
To delete lines start with some word e.g. Redirect
:g/^Redirect/d
Remove Dos / Windows carriage-return
To remove Carriage return in vi use following
:%s/^M//g
NOTE : to create “^M” use “Ctrl+v Ctrl+M” Regular ^M does not help.
Convert all character to lower OR upper case
NOTE : This will apply to whole file as we are using (%)
To convert upper case use following
:%s/\([a-z]\)/\u\1/g
To convert lower case use following
:%s/\([A-Z]\)/\l\1/g
Match Start of line Append End of line
To Match Start of line and append that line use following
(search Append end of line)
%g/^DocumentRoot/s/$/\/www/
Which append “/www” if start of line is “DocumentRoot”.
Also you can append after word by following.
%s/word/&test/g
So all word is get replaced by “wordtest”.
Saving file as root
At some point you would like to save file as root.
:w !sudo tee %
Marking
mk - record current location as mark k (redefines any previous mark k) 'k - return to line of mark k `k - return to mark k d'k - delete to line of mark k d`k - delete to mark k c'k - change text to line of mark k c`k - change text to mark k "ay'd - yank text into buffer a from cursor through line of mark d
Editing
o - open a new line above cursor(*) O - open a new line below cursor(*) i - insert text ahead of cursor(*) I - insert text at the beginning of the line(*) a - append text after the cursor(*) A - append text at the end of the line(*) c$ - change to end of the line (*) d$ - delete to end of the line C - same as c$ (*) D - same as d$ cG - change to end of the file (*) dG - delete to end of the file c0 - change to beginning of file (*) d0 - delete to beginning of file cc - change line (*) dd - delete line c'm - change from cursor through mark m (*) d'm - delete from cursor through mark m 3cc - change 3 lines (*) 3dd - delete 3 lines 8cw - change next 8 words (*) 8dw - delete next 8 words R - overwrite current line, starting at cursor(*) r - replace character at cursor s - substitute for character at cursor (*) 8s - substitute for next 8 characters (*) S - substitute for entire line (*) J - join two lines together . - repeats previous edit command xp - transpose two characters easESC - add a plural, and go back to command mode
Handling
h - move to the left                            
CTL-f - change display forward a page
j - `jump` down a line                          
CTL-b - change display back a page
k - move up a line                              
CTL-d - change display down half a page
l - move to the right                           
CTL-u - change display up half a page
- - same as k                                   
CTL-y - shift display down on screen
+ - same as j                                   
CTL-e - shift display up on screen
e - move to the end of a word                   
z. - recenter display around cursor
w - move forward to the beginning of a word     
z- - recenter display so cursor is at top
b - move backward to the beginning of a word    
z+ - recenter display aso cursor is at bottom
$ - move to the end of the line                 
zCR - recenter display so cursor is at top
0 - move to the beginning of the line           
'm - move to the beginning of the line of mark m
^ - move to the beginning of the line           
`m - move to the location of mark m
G - move to the end of the file                 
) - move forward 1 sentence
H - move to the top of the display              
( - move back 1 sentence
M - move to the middle of the display            
} - move forward 1 paragraph
L - move to the bottom of the display            
{ - move back 1 paragraph
B - move back to previous blank space           
20| - go to 20th character in the line
E - move ahead to next blank space              
CTL-L - clear and redraw
B - move back to previous blank space           
CR - same as j
CTL-G - print current location in the file       
:22 - move to line 22
6w - move forward 6 words
6b - move backward 6 words
8+ - move down 8 lines
Play with Buffers
yy - yank current line to unnamed buffer "j8yy - yank 8 lines into buffer j 19yy - yank next 19 lines to unnamed buffer "J8YY - append the next 8 lines into buffer j p - put unnamed buffer contents after cursor p - recover previous edit P - put unnamed buffer contents before cursor "1p - recover 2nd previous edit 19dd - delete next 19 lines, and put them in unnamed buffer "7p - recover 8th previous edit "bp - put the contents of buffer p into current file :11,14 ya w - yank lines 11 through 14 into buffer w :94 pu w - put contents of buffer w after line 94
VIM Scripts
Introduction to vim scripts  “:help vim-script-intro”
Running Vim scripts
There is many way to run vim script simple way is to run calling script from `source`
:source /home/yahoo/test.vim
You can also call command from script directly
:call MyBackupFunc(expand('%'), { 'all':1, 'save':'recent'})
You can do mapping of the keyboard using the variables.
:nmap ;s :source /home/yahoo/test.vim<CR>
The key sequence `;s` will execute the specified script file
You can call fucntion using the stored mapping same way.
:nmap \b :call MyBackupFunc(expand('%'), { 'all': 1 })<CR>
To call the function you need to call enter squence `\b`
syntax highlighting
VIM support syntax highlighting. to turn it on.
:syntax on
to turn it off
:syntax off
VIM Variable / Initialization (.vimrc)
OR
You can use .exrc
toggle syntax highlighting
function! ToggleSyntax() if exists("g:syntax_on") syntax off else syntax enable endif endfunction nmap <silent> ;s :call ToggleSyntax()<CR>
`;s` sequence to flip syntax highlighting on or off every time typed when you're in Normal mode.
nmap stands for “normal-mode key mapping”.
<silent>  option causes the mapping not to echo any command it's executing.
Creating centered titles
function! CapitalizeCenterAndMoveDown() s/\<./\u&/g "Built-in substitution capitalizes each word center "Built-in center command centers entire line +1 "Built-in relative motion (+1 line down) endfunction nmap <silent> \C :call CapitalizeCenterAndMoveDown()<CR>
single backslash used for continuation marker
call SetName( \ first_name, \ middle_initial, \ family_name \ )
Also you can use “|” to write two line on singe line.
echo "Starting..." | call Phase(1) | call Phase(2) | echo "Done"
You can comment using single quote, as double quote used to define a string.
also you can use “|” to escape the comment in some cases.
echo "> " |"Print generic prompt
Defining variable
to define variable you need to use word `let`
let name = "Damian" let height = 165 let interests = [ 'Cinema', 'Literature', 'World Domination', 101 ] let phone = { 'cell':5551017346, 'home':5558038728, 'work':'?' }
- scalar: a single value, such as a string or a number. For example: “Damian” or 165
- list: an ordered sequence of values delimited by square brackets, with implicit integer indices starting at zero. For example: ['Cinema', 'Literature', 'World Domination', 101]
- dictionary: an unordered set of values delimited by braces, with explicit string keys. For example: {'cell':5551017346, 'home':5558038728, 'work':'?'}
Basic Info
Variable scoping
g: varname The variable is global s: varname The variable is local to the current script file w: varname The variable is local to the current editor window t: varname The variable is local to the current editor tab b: varname The variable is local to the current editor buffer l: varname The variable is local to the current function a: varname The variable is a parameter of the current function v: varname The variable is one that Vim predefines
pseudovariables
& varname A Vim option (local option if defined, otherwise global) &l: varname A local Vim option &g: varname A global Vim option @ varname A Vim register $ varname An environment variable
