溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

shell中sed怎么用

發(fā)布時間:2021-12-18 09:28:35 來源:億速云 閱讀:162 作者:小新 欄目:系統(tǒng)運維

這篇文章給大家分享的是有關(guān)shell中sed怎么用的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

1.首先先來了解一下什么是sed?

sed叫做流編輯器,在shell腳本和Makefile中作為過濾器使用非常普遍,也就是把前一個程序的輸出引入sed的輸入,經(jīng)過一系列編輯命令轉(zhuǎn)換成為另一種格式輸出。下面我們通過一張原理圖來了解一下它的工作模式:

編輯命令的格式為,sed /pattern/action

shell中sed怎么用

經(jīng)過sed處理后文件內(nèi)容并沒有改變,除?使用重定向存儲輸出。sed主要用來自動編輯一個或多個文件;簡化對文件的反復(fù)操作;sed默認(rèn)按照Basic  規(guī)范基本匹配!也就是說類似于( ) { } | 等特殊字符需轉(zhuǎn)義,否則就不識別,或者是用擴(kuò)展模式也可以。

2. 下面重點介紹一下有關(guān)sed的參數(shù)及action的操作方法

(1)-n參數(shù),p命令的action

shell中sed怎么用

(2) d命令的action

shell中sed怎么用

shell中sed怎么用

(3)/pattern/s/pattern1/pattern2/:查找符合pattern的行,將該行***個匹配pattern1的字符串替換為pattern2

/pattern/s/pattern1/pattern2/g:查找符合pattern的行,將該行所有匹配pattern1的字符串替換為pattern2

shell中sed怎么用

shell中sed怎么用

這個操作不知道大家會不會聯(lián)想到vim編輯器中的底行模式搜索,它們是類似的。

下面總結(jié)一下sed中參數(shù)的選擇及執(zhí)行操作:

[plain] view plain copy

<strong>參數(shù)選擇:

-n:一般sed命令會把所有數(shù)據(jù)都輸出到屏幕,如果加入-n選項的話,則只會把經(jīng)過sed命令處理的行輸出到屏幕。

-e:允許對輸入數(shù)據(jù)應(yīng)用多條sed命令編輯。

-i:將修改結(jié)果直接寫入到讀取數(shù)據(jù)的文件,而不是由屏幕輸出。(1.修改了文件; 2.由cat可查看)

-f: 指定sed腳本的文件名。

action:

a:追加,在當(dāng)前行后添加一行或多行。

c:行替換,用c后面的字符串替換原數(shù)據(jù)行。

i:插入,在當(dāng)前行前插入一行或多行。

p:打印,輸出指定的行。

s:字符串替換,用一個字符串替換另外一個字符串。格式為”行范圍s/舊字符串/新字符串/g”(如果不加g的話,則表示只替換每行***個匹配的串)。

</strong>

以上沒有練習(xí)到的,有興趣的可以去嘗試嘗試!

3.再來介紹一下sed中的定址

定址用于決定對文件中哪些行進(jìn)行行編輯,地址的形式可以是數(shù)字、正則表達(dá)式、或二者的結(jié)合。如果沒有指定地址,sed將處理輸入文件的所有行。下面舉一些例子:

shell中sed怎么用  

shell中sed怎么用

sed '/start/ ,/end/d' file #刪除包含&rsquo;start&rsquo;行和&rsquo;end&rsquo;行之間的行

sed '/start/, 10d' file #刪除包含&rsquo;start&rsquo; 的行到第十行的內(nèi)容

4.模式空間和保持空間

(1)保持空間:用來存儲數(shù)據(jù),相當(dāng)于一個倉庫,它不能對數(shù)據(jù)進(jìn)行處理 ;

(2)模式空間:專門以行為單位對數(shù)據(jù)進(jìn)行處理。

一般情況下,如果不顯示的使用一些選項的話,是不會用到保持空間的。

[plain] view plain copy

<span style="color:#000000;"><strong>命令:

g:將保持空間的內(nèi)容拷貝到模式空間中,會將模式空間原來的值覆蓋掉。

G:將保持空間的內(nèi)容追加到模式空間中。

h:將模式空間的值拷貝到保持空間,會將保持空間原來的值覆蓋掉。

H:將模式空間的值追加到保持空間中。

d:刪除模式空間的所有行,并讀下一行到模式空間。

D:刪除模式空間的***行,不讀下一行到模式空間。

n:輸出模式空間的行,讀取下一行替換當(dāng)前模式空間的行,接著執(zhí)行下一條處理命令而不是***條命令。

N:讀入下一行,追加到模式空間行后面,此時模式空間中有兩行。

x:交換模式空間和保持空間的內(nèi)容。

</strong></span>

例1:給每行后面添加一行空行

shell中sed怎么用

例2:用sed模擬倒序(tac)打印的過程

shell中sed怎么用

例3.追加匹配行到文件末尾

shell中sed怎么用

例4:將一列內(nèi)容變?yōu)橐恍?/p>

shell中sed怎么用

例5:求出1-100的求和

shell中sed怎么用

例6:打印輸出奇數(shù)行和偶數(shù)行

shell中sed怎么用

5.使用標(biāo)簽

[plain] view plain copy

:a表示標(biāo)簽a;

ba表示跳轉(zhuǎn)到a標(biāo)簽;

$表示***一行;

!表示不做后續(xù)操作

所以,$!ba表示***一行不用跳轉(zhuǎn)到a標(biāo)簽,結(jié)束此次操作。

下面舉一個例子:

shell中sed怎么用

***補充一點:

[plain] view plain copy

與grep一樣,sed也支持特殊元字符來進(jìn)行模式查找、替換。不同的是,sed使用的正則表達(dá)式是括在斜杠線"/"之間的模式。

如果要把正則表達(dá)式分隔符"/"改為另一個字符,比如o,只要在這個字符前加一個反斜線,在字符后跟上正則表達(dá)式,再跟上這個字符即可。例如:sed -n  '\o^56op' datafile

^:行首定位符 /^my/ 匹配所有以my開頭的行;

$:行尾定位符 /my$/ 匹配所有以my結(jié)尾的行;

.:匹配除換行符以外的單個字符 /m..y/ 匹配包含字母m,后跟兩個任意字符,再跟字母y的行;

*:匹配零個或多個前導(dǎo)字符 /test*/ 匹配包含字符串 tes,后跟零個或多個 t 字母的行;

[]:匹配指定字符組內(nèi)的任一字符 /t[eE]st/ 匹配包含test 或 tEst 的行;

[^]:匹配不在指定字符組內(nèi)的任一字符 /t[^eE]st/ 匹配string 以t開頭,但st之前的那個字符不是e或E的行;

&:保存查找串以便在替換串中引用 s/test/*&*/g 符號&代表查找串。test將被替換為*test*

\<:詞?首定位符 /\<my/ 匹配包含以my開頭的單詞的行;

\>:詞尾定位符 /my\>/ 匹配包含以my結(jié)尾的單詞的行;

x\{m\}:連續(xù)m個x 如:/9\{5\}/ 匹配包含連續(xù)5個9的行;

x\{m,\}:至少m個x 如:/9\{5,\}/ 匹配包含至少連續(xù)5個9的行;

x\{m,n\}:至少m個,但不超過n個x 如:/9\{5,7\}/ 匹配包含連續(xù)5到7個9的行。 還有一個單元匹配--替換的問題:

shell中sed怎么用

感謝各位的閱讀!關(guān)于“shell中sed怎么用”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI