轉自:http://blog.csdn.net/lanxinju/article/details/5731843
一、查找 
查找命令 
/pattern<Enter> :向下查找pattern匹配字符串 
?pattern<Enter>:向上查找pattern匹配字符串 
使用了查找命令之后,使用如下兩個鍵快速查找: 
n:按照同一方向繼續查找 
N:按照反方向查找 
字符串匹配 
pattern是需要匹配的字符串,例如:
1:  /abc<Enter>      #查找abc 
         2:  / abc <Enter>    #查找abc單詞(注意前后的空格)  
        除此之外,pattern還可以使用一些特殊字符,包括(/、^、$、*、.),其中前三個這兩個是vi與vim通用的,“/”為轉義字符。
1:  /^abc<Enter>    #查找以abc開始的行  
         2:  /test$<Enter>    #查找以abc結束的行  
         3:  //^test<Enter>    #查找^tabc字符串 
          
二、替換 
基本替換 
1:  :s/vivian/sky/         #替換當前行第一個 vivian 為 sky 
         2:  :s/vivian/sky/g     #替換當前行所有 vivian 為 sky 
         3:  :n,$s/vivian/sky/     #替換第 n 行開始到最后一行中每一行的第一個 vivian 為 sky 
         4:  :n,$s/vivian/sky/g     #替換第 n 行開始到最后一行中每一行所有 vivian 為 sky 
         5:  (n 為數字,若 n 為 .,表示從當前行開始到最后一行) 
         6:   
         7:  :%s/vivian/sky/        #(等同於 :g/vivian/s//sky/) 替換每一行的第一個 vivian 為 sky 
         8:  :%s/vivian/sky/g    #(等同於 :g/vivian/s//sky/g) 替換每一行中所有 vivian 為 sky 
        
  可以使用 #或+ 作為分隔符,此時中間出現的 / 不會作為分隔符 
1:  :s#vivian/#sky/#         替換當前行第一個 vivian/ 為 sky/ 
         2:  :%s+/oradata/apras/+/user01/apras1+ ( 
         3:  使用+ 來 替換 / ): /oradata/apras/替換成/user01/apras1/ 
          
刪除文本中的^M 
問題描述:對於換行,window下用回車換行(0A0D)來表示,linux下是回車(0A)來表示。這樣,將window上的文件拷到unix上用時,總會有個^M,請寫個用在unix下的過濾windows文件的換行符(0D)的shell或c程序。 
使用命令:cat filename1 | tr -d “^V^M” > newfile; 
使用命令:sed -e “s/^V^M//” filename > outputfilename 
需要注意的是在1、2兩種方法中,^V和^M指的是Ctrl+V和Ctrl+M。你必須要手工進行輸入,而不是粘貼。 
在vi中處理:首先使用vi打開文件,然后按ESC鍵,接着輸入命令:
1:  :%s/^V^M// 
         2:  :%s/^M$//g 
        
如果上述方法無用,則正確的解決辦法是:
1:  tr -d “/r” < src >dest 
         2:  tr -d “/015″ dest 
         3:   
         4:  strings A>B 
          
其它用法 
1:  :s/str1/str2/          #用字符串 str2 替換行中首次出現的字符串 str1 
         2:  :s/str1/str2/g         #用字符串 str2 替換行中所有出現的字符串 str1 
         3:  :.,$ s/str1/str2/g     #用字符串 str2 替換正文當前行到末尾所有出現的字符串 str1 
         4:  :1,$ s/str1/str2/g     #用字符串 str2 替換正文中所有出現的字符串 str1 
         5:  :g/str1/s//str2/g      #功能同上 
        
從上述替換命令可以看到: 
g 放在命令末尾,表示對指定行的搜索字符串的每次出現進行替換;不加 g,表示只對指定行的搜索字符串的首次出現進行替換; 
g 放在命令開頭,表示對正文中所有包含搜索字符串的行進行替換操作。 
也就是說命令的開始可以添加影響的行,如果為g表示對所有行;命令的結尾可以使用g來表示是否對每一行的所有字符串都有影響。 
三、簡單的vim正則表達式規則 
在vim中有四種表達式規則: 
magic(/m):除了$.*^之外其他元字符都要加反斜杠 
nomagic(/M):除了$^之外其他元字符都要加反斜杠 
/v(即 very magic 之意):任何元字符都不用加反斜杠 
/V(即 very nomagic 之意):任何元字符都必須加反斜杠 
vim默認使用magic設置,這個設置也可以在正則表達式中通過 /m /M /v /V開關臨時切換。例如:
1:  //m.*          # 查找任意字符串 
         2:  //M.*          # 查找字符串 .* (點號后面跟個星號) 
         3:   
         4:  //v(a.c){3}$   # 查找行尾的abcaccadc 
         5:  //m(a.c){3}$   # 查找行尾的(abc){3} 
         6:  //M(a.c){3}$   # 查找行尾的(a.c){3} 
         7:  //V(a.c){3}$   # 查找任意位置的(a.c){3}$ 
        
推薦使用默認的magic設置,在這種情況下,常用的匹配有:
 1:  //<abc          #查找以test開始的字符串  
          2:  /abc/>          #查找以test結束的字符串  
          3:   
          4:  $       匹配一行的結束 
          5:  ^       匹配一行的開始 
          6:  /<      匹配一個單詞的開始,例如//<abc<Enter>:查找以abc開始的字符串 
          7:  />      匹配一個單詞的結束,例如/abc/><Enter>:查找以abc結束的字符串  
          8:   
          9:  *       匹配0或多次 
         10:  /+      匹配1或多次 
         11:  /=      匹配0或1次 
         12:   
         13:  .        匹配除換行符以外任意字符     
         14:  /a      匹配一個字符 
         15:  /d      匹配任一數字       
         16:  /u      匹配任一大寫字母 
         17:   
         18:  []      匹配范圍,如t[abcd]s 匹配tas tbs tcs tds 
         19:  /{}     重復次數,如a/{3,5} 匹配3~5個a 
         20:  /( /)   定義重復組,如a/(xy/)b 匹配ab axyb axyxyb axyxyxyb ... 
         21:  /|      或,如:for/|bar 表示匹配for或者bar 
         22:   
         23:  /%20c   匹配第20列 
         24:  /%20l   匹配第20行 
        
關於正則表達式的詳細信息,請參見參考文獻。
參考文獻: 
vi中的正則表達式 
vim運用正則表達式進行查找替換 
vi替換字符串
