Linux通過(guò)命令查找替換文本內(nèi)容的方法
Linux通過(guò)命令查找替換文本內(nèi)容的方法
Linux系統(tǒng)與其他系統(tǒng)相比,可以使用命令行進(jìn)行各種操作,是它一個(gè)突出的特點(diǎn)。接下來(lái)是小編為大家收集的Linux通過(guò)命令查找替換文本內(nèi)容的方法,歡迎大家閱讀。
Linux通過(guò)命令查找替換文本內(nèi)容的方法
如何使用命令進(jìn)行對(duì)文件內(nèi)容的查找與替換:
.批量查找某個(gè)目下文件的包含的內(nèi)容,例如:
# grep -rn "要找查找的文本" ./
2.批量查找并替換文件內(nèi)容。
# sed -i "s/要找查找的文本/替換后的文本/g" `grep -rl "要找查找的文本" ./`
sed的其他用法如下:
1、刪除行首空格
sed 's/^[ ]*//g' filename
sed 's/^ *//g' filename
sed 's/^[[:space:]]*//g' filename
2、行后和行前添加新行
行后:sed 's/pattern/&\n/g' filename
行前:sed 's/pattern/\n&/g' filename
&代表pattern
3、使用變量替換(使用雙引號(hào))
sed -e "s/$var1/$var2/g" filename
4、在第一行前插入文本
sed -i '1 i\插入字符串' filename
5、在最后一行插入
sed -i '$ a\插入字符串' filename
6、在匹配行前插入
sed -i '/pattern/ i "插入字符串"' filename
7、在匹配行后插入
sed -i '/pattern/ a "插入字符串"' filename
8、刪除文本中空行和空格組成的行以及#號(hào)注釋的行
grep -v ^# filename | sed /^[[:space:]]*$/d | sed /^$/d
find命令
find -name '要查找的文件名' | xargs perl -pi -e 's|被替換的字符串|替換后的字符串|g'
#查找替換當(dāng)前目錄下包含字符串并進(jìn)行替換
find -name '*.txt' | xargs perl -pi -e 's|智慧鄉(xiāng)村|北部山區(qū)|g'
#遞歸查找替換
find . -type f -name '*.html' | xargs perl -pi -e 's|智慧鄉(xiāng)村|北部山區(qū)|g'
#搜索目錄LOG包含顯示出來(lái)
find ./ -name '*log*' -type d
find ./ -name '*Log*' -type d more
當(dāng)然還可以利用 linux vim 批量替換
只對(duì)當(dāng)前行進(jìn)行替換:
Example
:s/XXX/YYY/g
,如果需要進(jìn)行全部替換:
Example
:%s/XXX/YYY/g
如果需要對(duì)指定部分進(jìn)行替換,可以用V進(jìn)入visual模式,再進(jìn)行
Example
:s/XXX/YYY/g
或者可以指定行數(shù)對(duì)指定范圍進(jìn)行替換:
Example
:10,31s/XXX/YYY/g
若需要顯示行號(hào),在vim下
Example
:set nu
取消顯示行號(hào):
Example
:set nonu
:s/well/good/ 替換當(dāng)前行第一個(gè) well 為 good
:s/well/good/g 替換當(dāng)前行所有 well 為 good
:n,$s/well/good/ 替換第 n 行開(kāi)始到最后一行中每一行的第一個(gè) well 為 good
:n,$s/well/good/g 替換第 n 行開(kāi)始到最后一行中每一行所有 well 為 good
n 為數(shù)字,若 n 為 .,表示從當(dāng)前行開(kāi)始到最后一行
:%s/well/good/(等同于 :g/well/s//good/) 替換每一行的第一個(gè) well 為 good
:%s/well/good/g(等同于 :g/well/s//good/g) 替換每一行中所有 well 為 good
可以使用 # 作為分隔符,此時(shí)中間出現(xiàn)的 / 不會(huì)作為分隔符
:s#well/#good/# 替換當(dāng)前行第一個(gè) well/ 為 good/
:%s#/usr/bin#/bin#g 可以把文件中所有路徑/usr/bin換成/bin
這就是使用命令進(jìn)行對(duì)文件內(nèi)容的查找與替換的方法了,如果還不清楚的用戶可以參考以上的步驟進(jìn)行對(duì)文件內(nèi)容的查找和替換。
Linux中替換文本中的字符串
(一)通過(guò)vi編輯器來(lái)替換。
vi/vim 中可以使用 :s 命令來(lái)替換字符串。以前只會(huì)使用編輯軟件進(jìn)行替換,今天發(fā)現(xiàn)該命令有很多種寫法(vi 真是強(qiáng)大啊,還有很多需要學(xué)習(xí)),記錄幾種在此,方便以后查詢。
:s/well/good/ 替換當(dāng)前行第一個(gè) well 為 good
:s/well/good/g 替換當(dāng)前行所有 well 為 good
:n,$s/well/good/ 替換第 n 行開(kāi)始到最后一行中每一行的第一個(gè) well 為 good
:n,$s/well/good/g 替換第 n 行開(kāi)始到最后一行中每一行所有 well 為 good
n 為數(shù)字,若 n 為 .,表示從當(dāng)前行開(kāi)始到最后一行
:%s/well/good/(等同于 :g/well/s//good/) 替換每一行的第一個(gè) well 為 good
:%s/well/good/g(等同于 :g/well/s//good/g) 替換每一行中所有 well 為 good
可以使用 # 作為分隔符,此時(shí)中間出現(xiàn)的 / 不會(huì)作為分隔符
:s#well/#good/# 替換當(dāng)前行第一個(gè) well/ 為 good/
:%s#/usr/bin#/bin#g
可以把文件中所有路徑/usr/bin換成/bin
(二)Sumly法直接替換文件中的字符串。(此法不用打開(kāi)文件即可替換字符串,而且可以批量替換多個(gè)文件。)
例1
執(zhí)行命令:
perl -p -i -e "s/China/Sumly/g" /www/*.htm /www/*.txt
上面的意思是說(shuō)將www文件夾下所有的htm和txt文件中的“China”都替換為“Sumly”
例2
執(zhí)行命令:
perl -p -i -e "s/memory_production/memory_production2/g" ./*.sql
上面的意思是將當(dāng)前目錄下所有的sql文件中的“memory_production”替換成“memory_production2”
看了“Linux通過(guò)命令查找替換文本內(nèi)容的方法”還想看: