vi查找替換命令詳解


一、查找

查找命令

/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替換字符串


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM