:%s/str1/str2/g 替換每一行中所有str1為str2 常用!
為清江浦等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計(jì)制作服務(wù),及清江浦網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè)、清江浦網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!基本替換
:s/str1/str2/ 替換當(dāng)前行第一個(gè)str1為str2
:s/str1/str2/g 替換當(dāng)前行所有str1為str2
:n,$s/str1/str2/ 替換第 n 行開始到最后一行中每一行的第一個(gè)str1為str2
:n,$s/str1/str2/g 替換第 n 行開始到最后一行中每一行所有str1為str2
(n 為數(shù)字,若 n 為 .,表示從當(dāng)前行開始到最后一行)
:%s/str1/str2/(等同于 :g/str1/s//str2/) 替換每一行的第一個(gè)str1為str2
:%s/str1/str2/g(等同于 :g/str1/s//str2/g) 替換每一行中所有str1為str2
:%s+/str11/str12/+/str21/str22+ (使用+ 來 替換 / ): /str11/str12/替換成/str21/str22/
(1)使用命令:cat oldfilename | tr -d “^V^M” > newfilename
(2)使用命令:sed -e “s/^V^M//” oldfilename > newfilename
需要注意的是在1、2兩種方法中,^V和^M指的是Ctrl+V和Ctrl+M。你必須要手工進(jìn)行輸入,而不是粘貼。
在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
:s/str1/str2/ 用字符串 str2 替換行中首次出現(xiàn)的字符串 str1
:s/str1/str2/g 用字符串 str2 替換行中所有出現(xiàn)的字符串 str1
:.,$ s/str1/str2/g 用字符串 str2 替換正文當(dāng)前行到末尾所有出現(xiàn)的字符串 str1
:1,$ s/str1/str2/g 用字符串 str2 替換正文中所有出現(xiàn)的字符串 str1
:g/str1/s//str2/g 功能同上
vi/vim 中可以使用 :s 命令來替換字符串。以前只會(huì)使用一種格式來全文替換,今天發(fā)現(xiàn)該命令有很多種寫法(vi 真是強(qiáng)大啊,還有很多需要學(xué)習(xí)),記錄幾種在此,方便以后查詢。
替換
:s/vivian/sky/ 替換當(dāng)前行第一個(gè) vivian 為 sky
:s/vivian/sky/g 替換當(dāng)前行所有 vivian 為 sky
:n,$s/vivian/sky/ 替換第 n 行開始到最后一行中每一行的第一個(gè) vivian 為 sky
:n,$s/vivian/sky/g 替換第 n 行開始到最后一行中每一行所有 vivian 為 sky
n 為數(shù)字,若 n 為 .,表示從當(dāng)前行開始到最后一行
:%s/vivian/sky/(等同于 :g/vivian/s//sky/) 替換每一行的第一個(gè) vivian 為 sky
:%s/vivian/sky/g(等同于 :g/vivian/s//sky/g) 替換每一行中所有 vivian 為 sky
可以使用 # 作為分隔符,此時(shí)中間出現(xiàn)的 / 不會(huì)作為分隔符
:s#vivian/#sky/# 替換當(dāng)前行第一個(gè) vivian/ 為 sky/
:%s+/oradata/apras/+/user01/apras1+ (使用+ 來 替換 / ): /oradata/apras/替換成/user01/apras1/
* ****
刪除文本中的^M
問題描述:對(duì)于換行,window下用回車換行(0A0D)來表示,linux下是回車(0A)來表示。這樣,將window上的文件拷到unix上用時(shí),總會(huì)有個(gè)^M.請(qǐng)寫個(gè)用在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。你必須要手工進(jìn)行輸入,而不是粘貼。
· 在vi中處理:首先使用vi打開文件,然后按ESC鍵,接著輸入命令:%s/^V^M//。
· :%s/^M$//g
如果上述方法無用,則正確的解決辦法是:
· tr -d "r" dest
· tr -d "5" dest
· strings A>B
其它
利用 :s 命令可以實(shí)現(xiàn)字符串的替換。具體的用法包括:
:s/str1/str2/ 用字符串 str2 替換行中首次出現(xiàn)的字符串 str1
:s/str1/str2/g 用字符串 str2 替換行中所有出現(xiàn)的字符串 str1
:.,$ s/str1/str2/g 用字符串 str2 替換正文當(dāng)前行到末尾所有出現(xiàn)的字符串 str1
:1,$ s/str1/str2/g 用字符串 str2 替換正文中所有出現(xiàn)的字符串 str1
:g/str1/s//str2/g 功能同上
從上述替換命令可以看到:g 放在命令末尾,表示對(duì)搜索字符串的每次出現(xiàn)進(jìn)行替換;不加 g,表示只對(duì)搜索
字符串的首次出現(xiàn)進(jìn)行替換;g 放在命令開頭,表示對(duì)正文中所有包含搜索字符串的行進(jìn)行替換操作。