真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

linux替換文字命令 linux 修改文件內(nèi)容命令

linux怎么批量替換文件內(nèi)容?

方法一:

創(chuàng)新互聯(lián)是一家專業(yè)提供鼓樓企業(yè)網(wǎng)站建設(shè),專注與網(wǎng)站設(shè)計、成都做網(wǎng)站、H5技術(shù)、小程序制作等業(yè)務(wù)。10年已為鼓樓眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)的建站公司優(yōu)惠進(jìn)行中。

使用perl ,命令如下:

下面這個例子就是將當(dāng)前目錄及所有子目錄下的所有pom.xml文件中的

”“

替換為

”“.

這里用到了Perl語言,

perl -pi -e 在Perl 命令中加上-e 選項,后跟一行代碼,那它就會像運行一個普通的Perl 腳本那樣運行該代碼.

從命令行中使用Perl 能夠幫助實現(xiàn)一些強(qiáng)大的、實時的轉(zhuǎn)換。認(rèn)真研究正則表達(dá)式,并正確地使用,將會為您省去大量的手工編輯工作。

方法二:

使用sed命令如下:

Linux下批量替換多個文件中的字符串的簡單方法。用sed命令可以批量替換多個文件中的字符串。

例如:我要把a(bǔ)aa替換 為bbb,執(zhí)行命令:

這是目前l(fā)inux最簡單的批量替換字符串命令了!

具體格式如下:

實例代碼:

linux之文本內(nèi)容替換命令sed

sed簡介:流編輯工具,用來對文本進(jìn)行過濾與替換操作。

sed流程:sed通過一次僅讀取一行內(nèi)容來對某些指令進(jìn)行處理后輸出。

1、sed通過文件或管道讀取文件內(nèi)容,但sed默認(rèn)并不直接修改源文件,而是將讀入的內(nèi)容復(fù)制到緩沖區(qū)中,稱之為模式空間。

2、所有的指令操作都是在模式空間找那個進(jìn)行

3、sed根據(jù)相應(yīng)的指令對模式空間中的內(nèi)容進(jìn)行處理并輸出結(jié)果,默認(rèn)輸出至標(biāo)準(zhǔn)輸出(即屏幕上)。

sed基本語法格式:

用法:sed[選項]...{腳本指令}[輸入文件]...

選項: -version 顯示sed版本

-help :顯示幫助文檔

-n,-quiet,-silent靜默輸出,默認(rèn)情況下,sed程序在所有的腳本指令執(zhí)行完畢后,將自動打印模式空間中的內(nèi)容。

-e script允許多個腳本指令被執(zhí)行

-f script-file從文件中讀取腳本指令,對編寫自動化腳本程序很實用

-i ,-in-place 該選項直接修改源文件

-l N 該選項指定l指令可以輸出的行長度,l指令為輸出非打印字符。

-posix 禁用GNU sed擴(kuò)展功能。

-r 在腳本指令中使用擴(kuò)展正則表達(dá)式。

-s,-separate 默認(rèn)情況下,sed將把輸入的多個文件名作為一個長的連續(xù)的輸入流。而GNU sed則允許把它們當(dāng)作單獨的文件。

-u,-unbuffered 最低限度的緩存輸入與輸出

a,append表示追加指令;

i,insert表示插入指令;

d,delete表示刪除指令;

s,substitution表示替換指令。

sed腳本指令的基本格式是:

[地址,即路徑]命令(有些命令僅可以對一行操作,有些可以對多行操作),命令也可以用花括號進(jìn)行組合,使命令序列可以作用于同一個地址。

address{

command1

command2

command3

}

sed的基本工作方式是:

sed的替換命令s:

1、全局替換 : s/old/new/g ,其中g(shù)為全局替換,用于替換所有出現(xiàn)的次數(shù); /如果和正則匹配的內(nèi)容沖突可以使用其他符號,如 : s@old@new@g

2、標(biāo)志位

為什么要有多行模式: 配置文件一般有單行出現(xiàn),但也有使用json或XML格式的配置文件,為多行出現(xiàn)。

多行模式處理命令N、D、P

linux服務(wù)器文本關(guān)鍵字搜索替換

1、vi命令下的查找和替換

1.1 vi下的查找

/helloEnter :向下查找hello匹配字符串

?helloEnter:向上查找hello匹配字符串

使用了查找命令之后,使用如下兩個鍵快速查找:

n:按照同一方向繼續(xù)查找

N:按照反方向查找

hello是需要匹配的字符串,例如:

/nameEnter? ? ? #查找name

/nameEnter? ? #查找name單詞(注意前后的空格)

除此之外,hello還可以使用一些特殊字符,包括(/、^、$、*、.),其中前三個這兩個是vi與vim通用的,“/”為轉(zhuǎn)義字符。

/^nameEnter? ? #查找以name開始的行

/name$Enter? ? #查找以name結(jié)束的行

//^nameEnter? ? #查找^name字符串

1.2 vi下的替換

:s/name/title/? ? ? ? #替換當(dāng)前行第一個 name 為 title

:s/name/title/g? ? #替換當(dāng)前行所有 name 為 title

:n,$s/name/title/? ? #替換第 n 行開始到最后一行中每一行的第一個 name 為 title

:n,$s/name/title/g? ? #替換第 n 行開始到最后一行中每一行所有 name 為 title

#(n 為數(shù)字,若 n 為 .,表示從當(dāng)前行開始到最后一行)

:%s/name/title/? ? ? ? #(等同于 :g/name/s//title/) 替換每一行的第一個 name 為 title

:%s/name/title/g? ? #(等同于 :g/name/s//title/g) 替換每一行中所有 name 為 title

可以使用 #或+ 作為分隔符,此時中間出現(xiàn)的 / 不會作為分隔符

:s#name/#title/#? ? ? ? 替換當(dāng)前行第一個 name/ 為 title/

:%s+/oradata/apras/+/user01/apras1+ (

使用+ 來 替換 / ): /oradata/apras/替換成/user01/apras1/

2.sed和grep配合

命令:sed -i s/yyyy/xxxx/g `grep yyyy -rl --include="*.txt" ./`

作用:將當(dāng)前目錄(包括子目錄)中所有txt文件中的yyyy字符串替換為xxxx字符串。其中,

-i 表示操作的是文件,``括起來的grep命令,表示將grep命令的的結(jié)果作為操作文件。

s/yyyy/xxxx/表示查找yyyy并替換為xxxx,后面跟g表示一行中有多個yyyy的時候,都替換,而不是僅替換第一個

另外,如果不需要查找子目錄,僅需要在當(dāng)前目錄替換,用sed命令就行了,命令如下:sed -i s/xxxx/yyyy/g ./*.txt

3.find命令查找和替換

命令格式:find -name '要查找的文件名' | xargs perl -pi -e 's|被替換的字符串|替換后的字符串|g'

#查找替換當(dāng)前目錄下包含字符串并進(jìn)行替換

find -name '*.txt' | xargs perl -pi -e 's|江蘇|上海|g'

#遞歸查找替換

find . -type f -name '*.html' | xargs perl -pi -e 's|蘇州|上海|g'

Linux命令之sed-替換字符串

1. sed -i 's/CANCEL_TIME/CANCEL_RECV_TIME/g' csv2drds-TF_B_PAYLOG_D.json

---指定文件替換,將文件中的CANCEL_TIME替換成CANCEL_RECV_TIME;

2.?sed -i 's/CANCEL_TIME/CANCEL_RECV_TIME/g' `grep CANCEL_TIME -rl ./*TF_B_PAYLOG_D*.json`

---批量文件替換,遞歸查找含CANCEL_TIME的文件,將所有文件中的CANCEL_TIME替換成CANCEL_RECV_TIME;

3. sed -i 's/\/tmp\/ditagent\/TF_B_PAYLOG_D.csv/\/vdata\/datapre\/281\/'"$filename"'/g' $jsonname

---帶/的字符串替換,將/tmp/ditagent/TF_B_PAYLOG_D.csv替換成/vdata/datapre/281/'"$filename"'

4.?sed -i 's/^/beginstring/g' *.txt

---在所有行首添加字符串;

5.??sed -i 's/$/endstring/g' *.txt

---在所有行末添加字符串

6. sed -i '2s/原字符串/替換字符串/g' *.txt

---替換第2行

7. sed -i?'$s/原字符串/替換字符串/g'?*.txt

---替換最后一行

8. sed?-i? '2,5s/原字符串/替換字符串/g'?*.txt

---替換2到5行

9. sed -i? '2,$s/原字符串/替換字符串/g'?*.txt

---替換2到最后一行

10. sed 's/\x80/|/g' test.dat |iconv -f gbk -t utf-8 testutf8.dat

---把test.dat中的歐元符號替換成豎線,再將文件gbk格式轉(zhuǎn)成utf8

-i選項是直接在文件中替換,不在終端輸出;

-r選項是所給的path中的目錄遞歸查找;

-l選項是輸出所有匹配到oldstring的文件;

s/表示替換

/g表示全局替換

shell :linux sed 批量替換字符串

Linux下批量替換多個文件中的字符串的簡單方法。用sed命令可以批量替換多個文件中的字符串。

命令如下:

sed -i "s/原字符串/新字符串/g" grep 原字符串 -rl 所在目錄

例如:我要把www目錄下的所有文件里的 charset=gb2312 替換為 charset=UTF-8,執(zhí)行命令:

sed -i "s/charset=gb2312/charset=UTF-8/g" `grep charset=gb2312 -rl /www`

即可。

解釋一下:

-i 表示inplace edit,就地修改文件

-r 表示搜索子目錄

-l 表示輸出匹配的文件名

這個命令組合很強(qiáng)大,要注意備份文件。

linux sed 替換

Linux sed 命令是利用腳本來處理文本文件。

sed 可依照腳本的指令來處理、編輯文本文件。

Sed 主要用來自動編輯一個或多個文件、簡化對文件的反復(fù)操作、編寫轉(zhuǎn)換程序等。

語法

參數(shù)說明:

regular_express.txt 文件內(nèi)容如下:

利用 sed 將 regular_express.txt 內(nèi)每一行結(jié)尾若為 . 則換成 !

:q:q

利用 sed 直接在 regular_express.txt 最后一行加入 # This is a test:

由於 $ 代表的是最后一行,而 a 的動作是新增,因此該文件最后新增 # This is a test!

sed 的 -i 選項可以直接修改文件內(nèi)容,這功能非常有幫助!舉例來說,如果你有一個 100 萬行的文件,你要在第 100 行加某些文字,此時使用 vim 可能會瘋掉!因為文件太大了!那怎辦?就利用 sed ?。⊥高^ sed 直接修改/取代的功能,你甚至不需要使用 vim 去修訂!

sed -i 常見用法(直接對文本文件進(jìn)行操作的)

替換掉每行的第一個字符串

替換掉所有的字符串 sed -i 's/原字符串/新字符串/g' file

去掉 “行首” 帶“@”的首字母@

特定字符串的行前插入新行

特定字符串的行后插入新行

特定字符串的刪除


本文名稱:linux替換文字命令 linux 修改文件內(nèi)容命令
網(wǎng)頁URL:http://weahome.cn/article/hpodec.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部