一、查詢
查詢命令
/pattern:向下查詢pattern匹配字串
?pattern:向上查詢pattern匹配字串
使用了查詢命令之後,使用如下兩個鍵快速查詢:
n:按照同一方向繼續查詢
n:按照反方向查詢
字串匹配
pattern是需要匹配的字串,例如:
1:/abc
<
enter
>
#查詢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:
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)$ # 查詢行尾的abcaccadc
5://m(a.c)$ # 查詢行尾的(abc)
6: //m(a.c)$ # 查詢行尾的(a.c)
7://v(a.c)$ # 查詢任意位置的(a.c)$
推薦使用預設的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個a
20: /( /) 定義重複組,如a/(xy/)b 匹配ab axyb axyxyb axyxyxyb ...
21:/| 或,如:for/|bar 表示匹配for或者bar
22:
23:/%20c 匹配第20列
24: /%20l 匹配第20行
關於正規表示式的詳細資訊,請參見參考文獻。
參考文獻:
vi中的正規表示式
vim運用正規表示式進行查詢替換
vi替換字串
vi查詢替換
1 在vi中使用的查詢替換方法利用 s 命令可以實現字串的替換。具體的用法包括 s str1 str2 用字串 str2 替換行中首次出現的字串 str1 s str1 str2 g 用字串 str2 替換行中所有出現的字串 str1 s str1 str2 g 用字串 str2 替換正文當前行到末...
vi查詢替換
vim替換命令的格式一般為 方括號中的內容為可選項,花括號中的內容為必選項 range s flag 其中 冒號 是這一類命令的開始 range 表示命令的作用域,即命令起作用的行的範圍 s是替換命令substitute的簡寫 和分別為待搜尋的模式串和所要替換成的替換串 用來界定和的起始 flag ...
vi查詢替換
在末行模式下 語法 range s s1 s2 option range 表示檢索範圍,省略時表示當前行 1,10表示從第 1 行到 10 行 表示整個檔案,同1,表示從當前行到檔案尾 s 為替換命令 s1 要被替換的串,s2 為替換的串 option 表示選項 g表示在全域性檔案中進行替換。c表示...