一、查找
查找命令
/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替換字符串