VI 查詢替換

2021-06-18 06:31:08 字數 4239 閱讀 3749

一、查詢

查詢命令 

/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表示...