vi 替換命令「找不到模式」解決

在linux vi編輯工具中使用替換命令操做時,會出現明明有匹配查找模式的數據。卻報「找不到模式」問題。linux

緣由是vi s///替換操做缺省針對行,若要生效,則需要將光標移動到指定行,再使用s///命令就能夠。shell

若要進行批量替換,則使用%s///命令,好比:vim

:%s/192.168.1.8/192.168.20.240/gwindows

當中g表示全局替換。緩存



vi替換命令參考:工具

http://hi.baidu.com/our_poll/item/bb87c33233af5bbe633afff4
學習

vi/vim 中可以使用 :s 命令來替換字符串。曾經僅僅會使用一種格式來全文替換,今天發現該命令有很是多種寫法(vi 真是強大啊,還有很是多需要學習)。記錄幾種在此,方便之後查詢。
:s/vivian/sky/ 替換當前行第一個 vivian 爲 sky

:s/vivian/sky/g 替換當前行所有 vivian 爲 sky

:n,$s/vivian/sky/ 替換第 n 行開始到最後一行中每一行的第一個 vivian 爲 sky

:n,$s/vivian/sky/g 替換第 n 行開始到最後一行中每一行所有 vivian 爲 sky

n 爲數字。若 n 爲 .。表示從當前行開始到最後一行

:%s/vivian/sky/(等同於 :g/vivian/s//sky/) 替換每一行的第一個 vivian 爲 sky

:%s/vivian/sky/g(等同於 :g/vivian/s//sky/g) 替換每一行中所有 vivian 爲 sky

可以使用 # 做爲分隔符,此時中間出現的 / 不會做爲分隔符(對於文件夾替換很是實用)

:s#vivian/#sky/# 替換當前行第一個 vivian/ 爲 sky/

:%s+/oradata/apras/+/user01/apras1+ (使用+ 來 替換 / ): /oradata/apras/替換成/user01/apras1/
要替換指定行的字符串。僅僅需在s前加上n,m(n到m行就能夠)
* ************************************

1.:s/vivian/sky/ 替換當前行第一個 vivian 爲 sky

:s/vivian/sky/g 替換當前行所有 vivian 爲 sky

2. :n,$s/vivian/sky/ 替換第 n 行開始到最後一行中每一行的第一個 vivian 爲 sky

:n,$s/vivian/sky/g 替換第 n 行開始到最後一行中每一行所有 vivian 爲 sky

(n 爲數字,若 n 爲 .,表示從當前行開始到最後一行)

3. :%s/vivian/sky/(等同於 :g/vivian/s//sky/) 替換每一行的第一個 vivian 爲 sky

:%s/vivian/sky/g(等同於 :g/vivian/s//sky/g) 替換每一行中所有 vivian 爲 sky

4. 可以使用 # 做爲分隔符,此時中間出現的 / 不會做爲分隔符

:s#vivian/#sky/# 替換當前行第一個 vivian/ 爲 sky/
5. 刪除文本中的^M
:1,$ /^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。須要注意的是在一、2兩種方法中。^V和^M指的是Ctrl+V和Ctrl+M。你必須要手工進行輸入。而不是粘貼。unix



· 在vi中處理:首先使用vi打開文件,而後按ESC鍵。接着輸入命令:%s/^V^M//。

· :%s/^M$//g

假設上述方法無用,則正確的解決的方法是:

· tr -d "r" <src >dest

· tr -d "5" dest

· strings A>B

6. 其餘

利用 :s 命令可以實現字符串的替換。ip

詳細的使用方法包含:

:s/str1/str2/ 用字符串 str2 替換行中首次出現的字符串 str1

:s/str1/str2/g 用字符串 str2 替換行中所有出現的字符串 str1

:.,$ s/str1/str2/g 用字符串 str2 替換正文當前行到末尾所有出現的字符串 str1

:1,$ s/str1/str2/g 用字符串 str2 替換正文中所有出現的字符串 str1

:g/str1/s//str2/g 功能同上

從上述替換命令可以看到:g 放在命令末尾。表示對搜索字符串的每次出現進行替換;不加 g,表示僅僅對搜索

字符串的首次出現進行替換;g 放在命令開頭,表示對正文中所有包括搜索字符串的行進行替換操做。

1. 全局替換
(1) v + G + $ 選定全部,而後輸入 :s/原始字符串/目標字符串/
(2) :%s/原始字符串/目標字符串/

2. 清除頁面中所有行尾的空白符:
:%s/\s\+$//

3. 清除所有空白
:%s/\(\s*\n\)\+/\r/

4. 去掉所有的//凝視
:%s!\s*//.*!!

5. 去掉所有的/* */凝視
:%s!\s*/\*\_.\{-}\*/\s*! !

6. 作某些內部數據反覆替換
有些時候咱們需要組織一些批量的數據進行命令行的運行,比方咱們需要利用前面的數據生成後面的數據,好比這種數據:
/var/database/aaa.txt
/var/database/bbb.txt
/var/database/ccc.txt

我想變成一個個的指令,比方變成一個個複製命令,拷貝到但前文件夾。那麼可以運行:
:%s/\(.*base\/\)\(.*\.txt\)/cp \1\2 \.\/\2/

變成了:
cp /var/database/aaa.txt ./aaa.txt
cp /var/database/bbb.txt ./bbb.txt
cp /var/database/ccc.txt ./ccc.txt

這裏關鍵是子模式的使用: () 中間的,\1 表明第一個找到的子模式,\2表明第二個,以此類推。vim裏面的()必須轉義,跟其它語言不同


7. 添加凝視(一個操做應用在多行)
比方需要添加#或者是//這樣的凝視:
Ctrl + v 定位到開始行。而後選定需要的行,而後運行 I 命令,而後輸入 # 或 //,而後按 Esc鍵兩次,就能夠把凝視操做應用到所有選定的行。記住選定不能使用v指令,而應該使用Ctrl + v (清除凝視請參考上面的方法)(v是按行選定,Ctrl + v 是依照列選定)

8. 對齊行
v 選定需要整齊的行,輸入 = 進行歸整

9. 打開多窗體
在vim中使用 :sp 文件名稱 打開行窗體(橫),使用 :vsp 文件名稱 打開列窗體(豎),使用 :q 關閉當前窗體,使用 :qa 關閉所有窗體,使用 Ctrl + w 在各個窗體中進行切換。


最大化窗體:Ctrl + w 激活某個窗體,而後 Shitf + - 進行最大化
改變窗體到指定行高度:Ctrl + w 激活窗體,10(需要變成的行大小數字),Shift + -,運行改變
添加若干行高度:Ctrl + w 激活窗體,10(需要添加的行大小數字),Shift + +。運行改變

10. 字符串/變量提示
在輸入內容狀態。按 Ctrl + P 則顯示所有本頁中定義的字符串,假設輸入字符串部份內容。而後按 Ctrl + p 則把所有你輸入字符串開頭的內容顯示出來。在輸入狀態下按 Ctrl + x 能過查看所有有效的其它方式刪除操做

:%s/r//g 刪除DOS方式的回車^M
:%s= *$== 刪除行尾空白

:%s/^(.*)n1/1$/ 刪除反覆行

:%s/^.{-}pdf/new.pdf/ 僅僅是刪除第一個pdf

:%s/<!--_.{-}-->// 又是刪除多行凝視(咦?爲何要說「又」呢?)

:g/s*^$/d 刪除所有空行 :這個好用有沒有人用過還有其它的方法嗎?
:g!/^dd/d 刪除不含字符串'dd'的行
:v/^dd/d 同上 (譯釋:v == g!,就是不匹配!



:g/str1/,/str2/d 刪除所有第一個含str1到第一個含str2之間的行


:v/./.,/./-1join 壓縮空行
:g/^$/,/./-j 壓縮空行

ndw 或 ndW 刪除光標處開始及其後的 n-1 個字符。

d0 刪至行首。 d$ 刪至行尾。 ndd 刪除當前行及其後 n-1 行。 x 或 X 刪除一個字符。 Ctrl+u 刪除輸入方式下所輸入的文本。 ^R 恢復u的操做 J 把下一行合併到當前行尾 V 選擇一行 ^V 按下^V後就能夠進行矩形的選擇了 aw 選擇單詞 iw 內部單詞(無空格) as 選擇句子 is 選擇句子(無空格) ap 選擇段落 ip 選擇段落(無空格) D 刪除到行尾 x,y 刪除與複製包括高亮區 dl 刪除當前字符(與x命令功能一樣) d0 刪除到某一行的開始位置 d^ 刪除到某一行的第一個字符位置(不包含空格或TAB字符) dw 刪除到某個單詞的結尾位置 d3w 刪除到第三個單詞的結尾位置 db 刪除到某個單詞的開始位置 dW 刪除到某個以空格做爲分隔符的單詞的結尾位置 dB 刪除到某個以空格做爲分隔符的單詞的開始位置 d7B 刪除到前面7個以空格做爲分隔符的單詞的開始位置 d) 刪除到某個語句的結尾位置 d4) 刪除到第四個語句的結尾位置 d( 刪除到某個語句的開始位置 d) 刪除到某個段落的結尾位置 d{ 刪除到某個段落的開始位置 d7{ 刪除到當前段落起始位置以前的第7個段落位置 dd 刪除當前行 d/text 刪除從文本中出現「text」中所指定字樣的位置, 一直向前直到下一個該字樣所出現的位置(但不包含該字樣)之間的內容 dfc 刪除從文本中出現字符「c」的位置,一直向前直到下一個該字符所出現的位置(包含該字符)之間的內容 dtc 刪除當前行直到下一個字符「c」所出現位置之間的內容 D 刪除到某一行的結尾 d$ 刪除到某一行的結尾 5dd 刪除從當前行所開始的5行內容 dL 刪除直到屏幕上最後一行的內容 dH 刪除直到屏幕上第一行的內容 dG 刪除直到工做緩存區結尾的內容 d1G 刪除直到工做緩存區開始的內容今天用了 4. 去掉所有的//凝視 :%s!\s*//.*!! 5. 去掉所有的/* */凝視 :%s!\s*/\*\_.\{-}\*/\s*! !

相關文章
相關標籤/搜索