vim字符串替換命令

:%s/str1/str2/g 替換每一行中全部str1爲str2 經常使用!linux

:s/str1/str2/g 替換當前行全部str1爲str2

基本替換
:s/str1/str2/ 替換當前行第一個str1爲str2shell

:s/str1/str2/g 替換當前行全部str1爲str2vim

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

:n,$s/str1/str2/g 替換第 n 行開始到最後一行中每一行全部str1爲str2ide

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

:%s/str1/str2/(等同於 :g/str1/s//str2/) 替換每一行的第一個str1爲str2unix

:%s/str1/str2/g(等同於 :g/str1/s//str2/g) 替換每一行中全部str1爲str2字符串

  1. 能夠使用 # 做爲分隔符,此時中間出現的 / 不會做爲分隔符
    :s#str1/#str2/# 替換當前行第一個str1/ 爲str2/

:%s+/str11/str12/+/str21/str22+ (使用+ 來 替換 / ): /str11/str12/替換成/str21/str22/string

  1. 文件中刪除^M
    問題描述:對於換行,Windows下用回車換行(0A0D)來表示,Linux下是回車(0A)來表示。這樣,將window上的文件拷到Unix上用時,總會有個^M,請寫個用在Unix下的過濾Windows文件的換行符(0D)的shell或c程序。有兩種方法能夠完成此目的:

(1)使用命令:cat oldfilename | tr -d 「^V^M」 > newfilenameit

(2)使用命令:sed -e 「s/^V^M//」 oldfilename > newfilename

須要注意的是在一、2兩種方法中,^V和^M指的是Ctrl+V和Ctrl+M。你必需要手工進行輸入,而不是粘貼。

在vim中處理:首先使用vim打開文件,而後按ESC鍵,接着輸入命令:

:%s/^V^M// 
:%s/^M$//g

若是上述方法無用,則正確的解決辦法是:

(1) tr -d "\r" < old_file_name > new_file_name 或者 cat oldfilename | tr -d "\r" > new_file_name

(2) tr -d "\015" < old_file_name > new_file_name或者 cat oldfilename | tr -d "\015" > new_file_name

strings A>B

  1. 其它技巧
    利用 :s 命令能夠實現字符串的替換。具體的用法包括:

: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 放在命令開頭,表示對正文中全部包含搜索字符串的行進行替換操做。

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/
  * ****

  刪除文本中的^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。你必需要手工進行輸入,而不是粘貼。  · 在vi中處理:首先使用vi打開文件,而後按ESC鍵,接着輸入命令:%s/^V^M//。  · :%s/^M$//g  若是上述方法無用,則正確的解決辦法是:  · tr -d "r" dest  · tr -d "5" dest  · strings A>B  其它  利用 :s 命令能夠實現字符串的替換。具體的用法包括:  :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 放在命令開頭,表示對正文中全部包含搜索字符串的行進行替換操做。

相關文章
相關標籤/搜索