linux下批量查找/替換文本內(nèi)容
一般在本地電腦上批量替換文本有許多工具可以做到扣草,比如sublime text ,但大多服務器上都是無圖形界面的,為此收集了幾條針對linux命令行 實現(xiàn)批量替換文本內(nèi)容的命令:
1.批量查找某個目下文件的包含的內(nèi)容,例如:
grep -rn "要找查找的文本" ./
2.批量查找并替換文件內(nèi)容。
sed -i "s/要找查找的文本/替換后的文本/g" grep -rl "要找查找的文本" ./
語法為 :[addr]s/源字符串/目的字符串/[option]
全局替換命令為::%s/源字符串/目的字符串/g
- 基本的替換
: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 為數(shù)字,若 n 為 .陶耍,表示從當前行開始到最后一行)
:%s/vivian/sky/(等同于 :g/vivian/s//sky/) 替換每一行的第一個 vivian 為 sky
:%s/vivian/sky/g(等同于 :g/vivian/s//sky/g) 替換每一行中所有 vivian 為 sky
- 可以使用 # 作為分隔符奋蔚,此時中間出現(xiàn)的 / 不會作為分隔符
: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 “VM” > newfile;
使用命令:sed -e “s/VM//” filename > outputfilename
需要注意的是在1酗钞、2兩種方法中,V和M指的是Ctrl+V和Ctrl+M来累。你必須要手工進行輸入砚作,而不是粘貼。
在vi中處理:首先使用vi打開文件嘹锁,然后按ESC鍵葫录,接著輸入命令:
:%s/VM//
:%s/^M$//g
如果上述方法無用,則正確的解決辦法是:
tr -d “\r” < src >dest
tr -d “\015〃 dest
strings A>B
- 其它用法
利用 :s 命令可以實現(xiàn)字符串的替換领猾。具體的用法包括:
:s/str1/str2/ 用字符串 str2 替換行中首次出現(xiàn)的字符串 str1
:s/str1/str2/g 用字符串 str2 替換行中所有出現(xiàn)的字符串 str1
:.,$ s/str1/str2/g 用字符串 str2 替換正文當前行到末尾所有出現(xiàn)的字符串 str1
:1,$ s/str1/str2/g 用字符串 str2 替換正文中所有出現(xiàn)的字符串 str1
:g/str1/s//str2/g 功能同上
從上述替換命令可以看到:g 放在命令末尾米同,表示對搜索字符串的每次出現(xiàn)進行替換;
不加 g摔竿,表示只對搜索字符串的首次出現(xiàn)進行替換面粮;g 放在命令開頭,表示對正文中所有包含搜索字符串的行進行替換操作继低。