vi查找替換命令詳解 一、查找查找命令/pattern :向下查找pattern匹配字符串?pattern:向上查找pattern匹配字符串使用了查找命令之后,使用如下兩個鍵快速查找:n:按照同一方向繼續(xù)查找N:按照反方向查找字符串匹配pattern是需要匹配的字符串,例如: 1: /abc #查找abc2: / abc #查找abc單詞(注意前后的空格) 除此之外,pattern還可以使用一些特殊字符,包括(/、^、$、*、.),其中前三個這兩個是vi與vim通用的,“/”為轉義字符。 1: /^abc #查找以abc開始的行 2: /test$ #查找以abc結束的行 3: //^test #查找^tabc字符串 二、替換基本替換 1: :s/vivian/sky/ #替換當前行第一個 vivian 為 sky2: :s/vivian/sky/g #替換當前行所有 vivian 為 sky3: :n,$s/vivian/sky/ #替換第 n 行開始到最后一行中每一行的第一個 vivian 為 sky4: :n,$s/vivian/sky/g #替換第 n 行開始到最后一行中每一行所有 vivian 為 sky5: (n 為數字,若 n 為 .,表示從當前行開始到最后一行)6: 7: :%s/vivian/sky/ #(等同于 :g/vivian/s//sky/) 替換每一行的第一個 vivian 為 sky8: :%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 >dest2: tr -d “/015″ dest3: 4: strings A>B 其它用法 1: :s/str1/str2/ #用字符串 str2 替換行中首次出現的字符串 str12: :s/str1/str2/g #用字符串 str2 替換行中所有出現的字符串 str13: :.,$ s/str1/str2/g #用字符串 str2 替換正文當前行到末尾所有出現的字符串 str14: :1,$ s/str1/str2/g #用字符串 str2 替換正文中所有出現的字符串 str15: :g/str1/s//str2/g #功能同上 從上述替換命令可以看到:g 放在命令末尾,表示對指定行的搜索字符串的每次出現進行替換;不加 g,表示只對指定行的搜索字符串的首次出現進行替換;g 放在命令開頭,表示對正文中所有包含搜索字符串的行進行替換操作。也就是說命令的開始可以添加影響的行,如果為g表示對所有行;命令的結尾可以使用g來表示是否對每一行的所有字符串都有影響。三、簡單的vim正則表達式規(guī)則在vim中有四種表達式規(guī)則: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}$ # 查找行尾的abcaccadc5: //m(a.c){3}$ # 查找行尾的(abc){3}6: //M(a.c){3}$ # 查找行尾的(a.c){3}7: //V(a.c){3}$ # 查找任意位置的(a.c){3}$ 推薦使用默認的magic設置,在這種情況下,常用的匹配有: 1: // #查找以test結束的字符串 3: 4: $ 匹配一行的結束 5: ^ 匹配一行的開始 6: /< 匹配一個單詞的開始,例如//:查找以abc開始的字符串 7: /> 匹配一個單詞的結束,例如/abc/>:查找以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 tds19: /{} 重復次數,如a/{3,5} 匹配3~5個a20: /( /) 定義重復組,如a/(xy/)b 匹配ab axyb axyxyb axyxyxyb ...21: /| 或,如:for/|bar 表示匹配for或者bar22: 23: /%20c 匹配第20列24: /%20l 匹配第20行