linux命令替換命令 linux中命令替換是什么

Linux下的shell編程 如何替換文件中的內(nèi)容

可以這樣做:

專注于為中小企業(yè)提供成都做網(wǎng)站、成都網(wǎng)站設(shè)計(jì)服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)鳳慶免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了千余家企業(yè)的穩(wěn)健成長(zhǎng),幫助中小企業(yè)通過(guò)網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。

方法1:sed -i 's/被替換的內(nèi)容/要替換成的內(nèi)容/' file

方法2:sed 's/被替換的內(nèi)容/要替換成的內(nèi)容/g' file file.out;mv file.out file。

擴(kuò)展資料:

Shell編程的常用技巧:

一、自動(dòng)補(bǔ)齊:在linux中對(duì)于命令或路徑,可以TAB鍵進(jìn)行自動(dòng)補(bǔ)全,以下事項(xiàng)需要注意:

1、只存在一個(gè)該輸入字符開(kāi)頭的命令或路徑,此時(shí)自動(dòng)補(bǔ)全;

2、存在多個(gè)該輸入字符開(kāi)頭的命令或路徑,此時(shí)第一次點(diǎn)擊TAB鍵無(wú)效,此時(shí)再次點(diǎn)擊TAB會(huì)羅列出所有該字符開(kāi)頭的命令或路徑,繼續(xù)輸入直到僅僅剩一個(gè)時(shí)自動(dòng)補(bǔ)全;

3、如果命令已經(jīng)是完整的,TAB鍵則是本來(lái)的移動(dòng)功能;而路徑的話要看命令自身的行為決定后續(xù)動(dòng)作。

二、歷史命令

1、history命令可以顯示歷史執(zhí)行過(guò)的命令;

2、使用!+序號(hào)執(zhí)行該序號(hào)對(duì)應(yīng)的命令;

3、使用!+字符執(zhí)行該字符開(kāi)頭的最后一次執(zhí)行的指令。

三、命令別名

1、實(shí)現(xiàn)別名:alias ddd="df -Th";

2、刪除別名:unalias ddd;

3、顯示所有別名命令列表:alias;

4、存放位置:~/.bashrc? (加入該文件后,重啟后不會(huì)消失)。

四、重定向

1、重定向標(biāo)準(zhǔn)輸入: 命令接收輸入的途徑由鍵盤(pán)改為文件;

2、重定向標(biāo)準(zhǔn)輸出: 將命令的執(zhí)行結(jié)果輸出到指定文件,而不是直接顯示到屏幕;

3、重定向標(biāo)準(zhǔn)輸出: 將命令的執(zhí)行結(jié)果追加輸出到指定文件;

4、重定向標(biāo)準(zhǔn)錯(cuò)誤:2 清除指定文件的內(nèi)容,并把標(biāo)準(zhǔn)錯(cuò)誤信息保存到指定文件;

5、重定向標(biāo)準(zhǔn)錯(cuò)誤:2 標(biāo)準(zhǔn)錯(cuò)誤信息追加到指定文件;

6、重定向標(biāo)準(zhǔn)輸出和標(biāo)準(zhǔn)錯(cuò)誤:? 將標(biāo)準(zhǔn)輸出、標(biāo)準(zhǔn)錯(cuò)誤信息全部保存到指定文件,而不是直接顯示在屏幕上。

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

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

1.1 vi下的查找

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

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

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

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

N:按照反方向查找

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

/nameEnter? ? ? #查找name

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

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

/^nameEnter? ? #查找以name開(kāi)始的行

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

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

1.2 vi下的替換

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

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

:n,$s/name/title/? ? #替換第 n 行開(kāi)始到最后一行中每一行的第一個(gè) name 為 title

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

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

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

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

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

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

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

使用+ 來(lái) 替換 / ): /oradata/apras/替換成/user01/apras1/

2.sed和grep配合

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

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

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

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

另外,如果不需要查找子目錄,僅需要在當(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命令行替換文件內(nèi)容

通過(guò)你的描述,替換命令如下:

1、tr 命令來(lái)進(jìn)行替換

[root@localhost ss1]# tr '111' '2222222' aa.txt

2、sed 命令

[root@localhost ss1]# sed ‘s/wyf/wzw/g’ ./person.txt

這里使用sed 內(nèi)置命令s 來(lái)實(shí)現(xiàn)替換功能,并且使用了全局替換標(biāo)志g 表示替換文件中匹配wyf的所有字符串。

溫馨提示:

1、tr 命令在接文件時(shí)比較特殊,需要輸入重定向符號(hào) “”

2、凡是在文本中出現(xiàn)的“111”均應(yīng)轉(zhuǎn)換成“222222”,而不是僅僅將單個(gè)進(jìn)行轉(zhuǎn)換,這個(gè)要注意。

3、在使用sed 命令時(shí),要注意一下語(yǔ)法格式,將要替換的文本“wyf”放在第一個(gè)和第二個(gè)“/” 之間,將替換后的文本“wzw”放到第二個(gè)和第三個(gè)“/” 之間。這個(gè)要注意。

以上就是我的回答,在具體操作時(shí),可能會(huì)有出入,如有問(wèn)題可??私信?+?關(guān)注,我會(huì)第一時(shí)間來(lái)進(jìn)行回復(fù)追答,希望我的回答能幫到你。

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中的歐元符號(hào)替換成豎線,再將文件gbk格式轉(zhuǎn)成utf8

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

-r選項(xiàng)是所給的path中的目錄遞歸查找;

-l選項(xiàng)是輸出所有匹配到oldstring的文件;

s/表示替換

/g表示全局替換

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

sed簡(jiǎn)介:流編輯工具,用來(lái)對(duì)文本進(jìn)行過(guò)濾與替換操作。

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

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

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

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

sed基本語(yǔ)法格式:

用法:sed[選項(xiàng)]...{腳本指令}[輸入文件]...

選項(xiàng): -version 顯示sed版本

-help :顯示幫助文檔

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

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

-f script-file從文件中讀取腳本指令,對(duì)編寫(xiě)自動(dòng)化腳本程序很實(shí)用

-i ,-in-place 該選項(xiàng)直接修改源文件

-l N 該選項(xiàng)指定l指令可以輸出的行長(zhǎng)度,l指令為輸出非打印字符。

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

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

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

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

a,append表示追加指令;

i,insert表示插入指令;

d,delete表示刪除指令;

s,substitution表示替換指令。

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

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

address{

command1

command2

command3

}

sed的基本工作方式是:

sed的替換命令s:

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

2、標(biāo)志位

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

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

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

方法一:

使用perl ,命令如下:

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

”“

替換為

”“.

這里用到了Perl語(yǔ)言,

perl -pi -e 在Perl 命令中加上-e 選項(xiàng),后跟一行代碼,那它就會(huì)像運(yùn)行一個(gè)普通的Perl 腳本那樣運(yùn)行該代碼.

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

方法二:

使用sed命令如下:

Linux下批量替換多個(gè)文件中的字符串的簡(jiǎn)單方法。用sed命令可以批量替換多個(gè)文件中的字符串。

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

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

具體格式如下:

實(shí)例代碼:

標(biāo)題名稱:linux命令替換命令 linux中命令替換是什么
鏈接分享:http://m.kartarina.com/article10/hjgjdo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作域名注冊(cè)響應(yīng)式網(wǎng)站網(wǎng)站營(yíng)銷軟件開(kāi)發(fā)手機(jī)網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

手機(jī)網(wǎng)站建設(shè)
主站蜘蛛池模板: 18禁成年无码免费网站无遮挡| 国产精品无码素人福利不卡| 亚洲动漫精品无码av天堂| 91精品久久久久久无码| 免费无码专区毛片高潮喷水| 国产办公室秘书无码精品99 | 黄A无码片内射无码视频| 免费无码作爱视频| 国产精品无码久久综合| 日韩av无码一区二区三区| 国产成人精品无码专区| 亚洲AV无码AV男人的天堂| 人妻系列AV无码专区| 无码中文字幕乱在线观看| 精品无码成人久久久久久| 色综合久久无码五十路人妻| 国产成人无码精品久久久免费| 在线看无码的免费网站| 久久亚洲av无码精品浪潮 | 97无码免费人妻超级碰碰夜夜| 国产在线无码一区二区三区视频| 四虎国产精品永久在线无码| 无码国产精品一区二区免费16 | 亚洲va中文字幕无码| 国产午夜无码片在线观看| 亚洲乱亚洲乱妇无码| 97久久精品无码一区二区天美| 久久久久亚洲精品无码系列 | 亚洲AV无码专区在线电影成人 | 国产成人精品无码播放| 久久精品无码一区二区app| 国产成人无码免费视频97| 无码国模国产在线观看免费| 亚洲av无码偷拍在线观看| 乱色精品无码一区二区国产盗 | 中文字幕av无码专区第一页| 无码久久精品国产亚洲Av影片| 亚洲AV无码一区二区三区系列| 久久午夜夜伦鲁鲁片免费无码 | 色综合久久中文字幕无码| 18禁无遮挡无码国产免费网站|