vi查詢替換命令詳解
一、查詢
查詢命令
/pattern :向下查詢pattern匹配字串
?pattern:向上查詢pattern匹配字串
使用了查詢命令之後,使用如下兩個鍵快速查詢:
n:按照同一方向繼續查詢
N:按照反方向查詢
字串匹配
pattern是需要匹配的字串,例如:
1: /abc #查詢abc
2: / abc #查詢abc單詞(注意前後的空格)
除此之外,pattern還可以使用一些特殊字元,包括(/、^、$、*、.),其中前三個這兩個是vi與vim通用的,“/”為跳脫字元。
1: /^abc #查詢以abc開始的行
2: /test$ #查詢以abc結束的行
3: //^test #查詢^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: :%s/vivian/sky/ #(等同於 :g/vivian/s//sky/) 替換每一行的第一個 vivian 為 sky
7: :%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: //
2: /abc/> #查詢以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 tds
19: /{} 重複次數,如a/{3,5} 匹配3~5個a
20: /( /) 定義重複組,如a/(xy/)b 匹配ab axyb axyxyb axyxyxyb ...
21: /| 或,如:for/|bar 表示匹配for或者bar
22: /%20c 匹配第20列
23: /%20l 匹配第20行
關於正規表示式的詳細資訊,請參見參考文獻。
查詢命令
/pattern
?pattern
使用了查詢命令之後,使用如下兩個鍵快速查詢:
n:按照同一方向繼續查詢
N:按照反方向查詢
字串匹配
pattern是需要匹配的字串,例如:
1: /abc
2: / abc
除此之外,pattern還可以使用一些特殊字元,包括(/、^、$、*、.),其中前三個這兩個是vi與vim通用的,“/”為跳脫字元。
1: /^abc
2: /test$
3: //^test
二、替換
基本替換
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: :%s/vivian/sky/ #(等同於 :g/vivian/s//sky/) 替換每一行的第一個 vivian 為 sky
7: :%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: //
2: /abc/> #查詢以test結束的字串
3:
4: $ 匹配一行的結束
5: ^ 匹配一行的開始
6: /< 匹配一個單詞的開始,例如//
7: /> 匹配一個單詞的結束,例如/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: /%20c 匹配第20列
23: /%20l 匹配第20行
關於正規表示式的詳細資訊,請參見參考文獻。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/30031456/viewspace-1358805/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- vi替換命令
- vi 替換命令引數
- vi的替換命令說明
- Linuxvivim查詢和替換字串命令Linux字串
- [轉]Vi/Vim查詢替換使用方法 - HelloSUN - 部落格園
- Linux Shell 字串操作(長度,查詢,替換)詳解Linux字串
- Linux Shell 字串操作(長度/查詢/替換)詳解Linux字串
- vim下多行查詢替換簡單命令
- vim查詢替換
- vi命令詳解
- linux shell 字串操作(長度,查詢,替換)詳解 BASHLinux字串
- vi替換字串(zz)字串
- 字串查詢和替換字串
- vi命令詳解(轉)
- Linux的VI (連線行,查詢和替換,多檔案編輯)Linux
- Linux vi替換字串Linux字串
- Vi中的替換字串字串
- VI中的批量替換
- PostgreSQL 查詢替換函式SQL函式
- liunx下vi命令詳解
- vi命令鳥哥詳解
- js字串查詢和替換功能JS字串
- vi 正規表示式替換
- 如何在word中進行查詢與替換 word文件中的替換與查詢功能
- Linux sed 命令字串替換使用方法詳解Linux字串
- D4.玩轉查詢與替換
- 在LoadRunner中查詢和替換字串字串
- 命行下的查詢與替換字串字串
- 使用sed 命令查詢和替換檔案中的字串的方法總結字串
- 使用 sed 命令查詢和替換檔案中的字串的 16 個示例字串
- Python字串string的查詢和替換Python字串
- Find and Replace Pattern(C++查詢和替換模式)C++模式
- Word文件格式也能查詢與替換
- VC++基礎 字串的查詢與替換C++字串
- 批次word文件內容查詢替換的方法
- rhel5 vi 批量替換匹配的字串字串
- 替換快捷鍵ctrl加什麼 word查詢和替換快捷鍵是什麼
- 詳解 packagit 用了什麼黑魔法,並可完全替換 artisan 命令Git