shell字符串替換

linux shell 字符串中指定字符替換

  1. echo ${string/23/bb} //abc1bb42341 替換一次
  2. echo ${string//23/bb} //abc1bb4bb41 雙斜杠替換所有匹配
  3. echo ${string/#abc/bb} //bb12342341 #以什么開頭來匹配,根php中的^有點像
  4. echo {string/%41/bb} //abc123423bb %以什么結(jié)尾來匹配,根php中的有點像

假設(shè)定義了一個變量為:
代碼如下: file=/dir1/dir2/dir3/my.file.txt

可以用{ }分別替換得到不同的值:{file#/}:刪掉第一個 / 及其左邊的字符串:dir1/dir2/dir3/my.file.txt
{file##*/}:刪掉最后一個 / 及其左邊的字符串:my.file.txt{file#
.}:刪掉第一個 . 及其左邊的字符串:file.txt
{file##*.}:刪掉最后一個 . 及其左邊的字符串:txt{file%/}:刪掉最后一個 / 及其右邊的字符串:/dir1/dir2/dir3
{file%%/*}:刪掉第一個 / 及其右邊的字符串:(空值){file%.
}:刪掉最后一個 . 及其右邊的字符串:/dir1/dir2/dir3/my.file
${file%%.*}:刪掉第一個 . 及其右邊的字符串:/dir1/dir2/dir3/my

記憶的方法為:

是 去掉左邊(鍵盤上#在 $ 的左邊)

%是去掉右邊(鍵盤上% 在$ 的右邊)
單一符號是最小匹配;兩個符號是最大匹配

sed命令

a\ 在當(dāng)前行下面插入文本。
i\ 在當(dāng)前行上面插入文本。
c\ 把選定的行改為新的文本。
d 刪除,刪除選擇的行。
D 刪除模板塊的第一行。
s 替換指定字符
h 拷貝模板塊的內(nèi)容到內(nèi)存中的緩沖區(qū)。
H 追加模板塊的內(nèi)容到內(nèi)存中的緩沖區(qū)。
g 獲得內(nèi)存緩沖區(qū)的內(nèi)容,并替代當(dāng)前模板塊中的文本。
G 獲得內(nèi)存緩沖區(qū)的內(nèi)容,并追加到當(dāng)前模板塊文本的后面。
l 列表不能打印字符的清單。
n 讀取下一個輸入行,用下一個命令處理新的行而不是用第一個命令。
N 追加下一個輸入行到模板塊后面并在二者間嵌入一個新行,改變當(dāng)前行號碼。
p 打印模板塊的行。
P(大寫) 打印模板塊的第一行。
q 退出Sed。
b lable 分支到腳本中帶有標(biāo)記的地方,如果分支不存在則分支到腳本的末尾。
r file 從file中讀行。
t label if分支,從最后一行開始,條件一旦滿足或者T,t命令,將導(dǎo)致分支到帶有標(biāo)號的命令處,或者到腳本的末尾。
T label 錯誤分支,從最后一行開始,一旦發(fā)生錯誤或者T,t命令,將導(dǎo)致分支到帶有標(biāo)號的命令處,或者到腳本的末尾。
w file 寫并追加模板塊到file末尾。
W file 寫并追加模板塊的第一行到file末尾。
! 表示后面的命令對所有沒有被選定的行發(fā)生作用。
= 打印當(dāng)前行號碼。
# 把注釋擴展到下一個換行符以前。 </pre>

sed替換標(biāo)記

g 表示行內(nèi)全面替換。
p 表示打印行。
w 表示把行寫入一個文件。
x 表示互換模板塊中的文本和緩沖區(qū)中的文本。
y 表示把一個字符翻譯為另外的字符(但是不用于正則表達(dá)式)
\1 子串匹配標(biāo)記
& 已匹配字符串標(biāo)記</pre>

sed元字符集

^ 匹配行開始,如:/^sed/匹配所有以sed開頭的行。
** 匹配行結(jié)束,如:/sed/匹配所有以sed結(jié)尾的行。
. 匹配一個非換行符的任意字符,如:/s.d/匹配s后接一個任意字符,最后是d。
***** 匹配0個或多個字符,如:/
sed/匹配所有模板是一個或多個空格后緊跟sed的行。
[] 匹配一個指定范圍內(nèi)的字符,如/[ss]ed/匹配sed和Sed。
[^] 匹配一個不在指定范圍內(nèi)的字符,如:/[^A-RT-Z]ed/匹配不包含A-R和T-Z的一個字母開頭,緊跟ed的行。
(..) 匹配子串,保存匹配的字符,如s/(love)able/\1rs,loveable被替換成lovers。
& 保存搜索字符用來替換其他字符,如s/love/
&/,love這成love*。
< 匹配單詞的開始,如:/<love/匹配包含以love開頭的單詞的行。
> 匹配單詞的結(jié)束,如/love>/匹配包含以love結(jié)尾的單詞的行。
x{m} 重復(fù)字符x,m次,如:/0{5}/匹配包含5個0的行。
x{m,} 重復(fù)字符x,至少m次,如:/0{5,}/匹配至少有5個0的行。
x{m,n} 重復(fù)字符x,至少m次,不多于n次,如:/0{5,10}/匹配5~10個0的行。

sed用法實例

替換操作:s命令

替換文本中的字符串:

sed 's/book/books/' file

-n選項p命令一起使用表示只打印那些發(fā)生替換的行:

sed -n 's/test/TEST/p' file

直接編輯文件選項-i,會匹配file文件中每一行的第一個book替換為books:

sed -i 's/book/books/g' file

全面替換標(biāo)記g

使用后綴 /g 標(biāo)記會替換每一行中的所有匹配:

sed 's/book/books/g' file

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 知識點 sort uniq cut wc sed命令 awk命令 crontab定時器 sort sort 命令對...
  • 原文鏈接:sed命令_Linux sed 命令用法詳解:功能強大的流式文本編輯器 http://man.linu...
    e2ae5d4bd7c1閱讀 837評論 0 1
  • 行前或行后插入 sed 'p;s/^.*$/--------/' file awk '{print $0;prin...
    不排版閱讀 611評論 0 0
  • sed是一種流編輯器,它是文本處理中非常好的工具,能夠完美的配合正則表達(dá)式使用,功能不同凡響。處理時,把當(dāng)前處理的...
    Summer_1981閱讀 738評論 0 1
  • 官網(wǎng) 中文版本 好的網(wǎng)站 Content-type: text/htmlBASH Section: User ...
    不排版閱讀 4,696評論 0 5

友情鏈接更多精彩內(nèi)容