ホームページ > 運用・保守 > Linuxの運用と保守 > sedの使い方を詳しく解説

sedの使い方を詳しく解説

大家讲道理
リリース: 2017-05-28 10:24:14
オリジナル
2236 人が閲覧しました

はじめに

sed は、コンテンツを一度に 1 行ずつ処理するオンライン エディタ です。処理中、現在処理されている行は「パターン空間」と呼ばれる一時バッファーに保存され、sed コマンドを使用してバッファーの内容が処理されます。処理が完了すると、バッファーの内容がサーバーに送信されます。画面。次に、次の行を処理し、ファイルの終わりまで繰り返します。リダイレクトを使用して出力を保存しない限り、ファイルの内容は変更されません。 Sed は主に、1 つまたは複数のファイルの書き込み変換プログラムなどの繰り返し操作を簡素化するために使用されます。

sedはパラメータを使用します


sedの使い方を詳しく解説

[root@www ~]# sed [-nefr] [动作]
选项与参数:
-n :使用安静(silent)模式。在一般 sed 的用法中,所有来自 STDIN 的数据一般都会被列出到终端上。但如果加上 -n 参数后,则只有经过sed 特殊处理的那一行(或者动作)才会被列出来。
-e :直接在命令列模式上进行 sed 的动作编辑;
-f :直接将 sed 的动作写在一个文件内, -f filename 则可以运行 filename 内的 sed 动作;
-r :sed 的动作支持的是延伸型正规表示法的语法。(默认是基础正规表示法语法)
-i :直接修改读取的文件内容,而不是输出到终端。

动作说明: [n1[,n2]]function
n1, n2 :不见得会存在,一般代表『选择进行动作的行数』,举例来说,如果我的动作是需要在 10 到 20 行之间进行的,则『 10,20[动作行为] 』

function:
a :新增, a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行)~
c :取代, c 的后面可以接字串,这些字串可以取代 n1,n2 之间的行!
d :删除,因为是删除啊,所以 d 后面通常不接任何咚咚;
i :插入, i 的后面可以接字串,而这些字串会在新的一行出现(目前的上一行);
p :列印,亦即将某个选择的数据印出。通常 p 会与参数 sed -n 一起运行~
s :取代,可以直接进行取代的工作哩!通常这个 s 的动作可以搭配正规表示法!例如 1,20s/old/new/g 就是啦!
ログイン後にコピー

sedの使い方を詳しく解説

行単位で追加/削除


/etc/passwd の内容をリストし、その行を出力します番号を入力すると同時に、2~5行目を削除してください。


[root@www ~]# nl /etc/passwd | sed '2,5d'
1 root:x:0:0:root:/root:/bin/bash
6 sync:x:5:0:sync:/sbin:/bin/sync
7 shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
.....(后面省略).....
ログイン後にコピー



sed のアクションは '2,5d'、つまり d は削除です。 2行目から5行目を削除したため、表示されるデータには2行目から5行目は含まれていません~ なお、本来は sed -e を発行する必要がありますが、-e なしでも動作します。同時に、sed に続くアクションは 2 つの一重引用符 ''! で囲む必要があることにも注意してください。 2 2 行目を削除するだけです

nl /etc/passwd | sed '2d'
ログイン後にコピー


最後から 3 行目を削除します

R

 nl /etc/passwd | sed '3,$d'
ログイン後にコピー
E




(つまり、追加3 行目に「お茶を飲みますか?」という単語を追加します。 2行以上追加したい場合は、2行目の後に「お茶を飲むか…」「ビールを飲む?」のように2行追加します



[root@www ~]# nl /etc/passwd | sed '2a drink tea'
1 root:x:0:0:root:/root:/bin/bash
2 bin:x:1:1:bin:/bin:/sbin/nologin
drink tea
3 daemon:x:2:2:daemon:/sbin:/sbin/nologin
.....(后面省略).....
ログイン後にコピー


新しい行を作成するには、各行の間にバックスラッシュ「 」を使用する必要があります。追加してください。したがって、上記の例では、最初の行の最後に が存在することがわかります。

sedの使い方を詳しく解説行単位で置換して表示

2〜5行目の内容を「2〜5番なし」に置き換えますか? sedの使い方を詳しく解説

 nl /etc/passwd | sed '2i drink tea'
ログイン後にコピー


このメソッドを通じて、データの行全体を置き換えることができます。


/etc/passwd ファイルの行 5 ~ 7 のみをリストします


[root@www ~]# nl /etc/passwd | sed '2a Drink tea or ......\
> drink beer ?'
1 root:x:0:0:root:/root:/bin/bash
2 bin:x:1:1:bin:/bin:/sbin/nologin
Drink tea or ......
drink beer ?
3 daemon:x:2:2:daemon:/sbin:/sbin/nologin
.....(后面省略).....
ログイン後にコピー


sed の行ごとの表示機能を使用して、ファイル内の特定の行を選択して表示できます。表示する行番号。

データの検索と表示


ルートキーワードを含む行を検索
/etc/passwd

[root@www ~]# nl /etc/passwd | sed '2,5c No 2-5 number'
1 root:x:0:0:root:/root:/bin/bash
No 2-5 number
6 sync:x:5:0:sync:/sbin:/bin/sync
.....(后面省略).....
ログイン後にコピー


root が見つかった場合は、 , を除くすべての行を出力します。一致する行も出力します。

sedの使い方を詳しく解説 -n を使用すると、テンプレートを含む行のみが出力されます。

[root@www ~]# nl /etc/passwd | sed -n '5,7p'
5 lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
6 sync:x:5:0:sync:/sbin:/bin/sync
7 shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
ログイン後にコピー
sedの使い方を詳しく解説

データの検索と削除

/etc/passwd内のrootを含む行を全て削除し、他の行を出力


nl /etc/passwd | sed '/root/p'
1  root:x:0:0:root:/root:/bin/bash
1  root:x:0:0:root:/root:/bin/bash
2  daemon:x:1:1:daemon:/usr/sbin:/bin/sh
3  bin:x:2:2:bin:/bin:/bin/sh
4  sys:x:3:3:sys:/dev:/bin/sh
5  sync:x:4:65534:sync:/bin:/bin/sync
....下面忽略
ログイン後にコピー


データを検索してコマンドを実行します


パターン Eastern に一致する行を見つけたら、

/etc/passwd を検索し、root に対応する行を見つけて、中括弧で囲まれた一連のコマンドを実行します (各コマンドはセミコロンで区切られます)。ここで bash を blueshell に置き換えて、次の行を出力します:

nl /etc/passwd | sed -n '/root/p'
1  root:x:0:0:root:/root:/bin/bash
ログイン後にコピー

/etc/passwd の最初の bash キーワードのみを blueshell に置き換える場合は、

exit

nl /etc/passwd | sed  '/root/d'
2  daemon:x:1:1:daemon:/usr/sbin:/bin/sh
3  bin:x:2:2:bin:/bin:/bin/sh
....下面忽略
#第一行的匹配root已经删除了
ログイン後にコピー


最後のqは終了です。

数据的搜寻并替换

除了整行的处理模式之外, sed 还可以用行为单位进行部分数据的搜寻并取代。基本上 sed 的搜寻与替代的与 vi 相当的类似!他有点像这样:


sed 's/要被取代的字串/新的字串/g'
ログイン後にコピー


 

先观察原始信息,利用 /sbin/ifconfig 查询 IP


[root@www ~]# /sbin/ifconfig eth0
eth0 Link encap:Ethernet HWaddr 00:90:CC:A6:34:84
inet addr:192.168.1.100 Bcast:192.168.1.255 Mask:255.255.255.0
inet6 addr: fe80::290:ccff:fea6:3484/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
.....(以下省略).....
ログイン後にコピー



本机的ip是192.168.1.100。

 

将 IP 前面的部分予以删除


[root@www ~]# /sbin/ifconfig eth0 | grep 'inet addr' | sed 's/^.*addr://g'
192.168.1.100 Bcast:192.168.1.255 Mask:255.255.255.0
ログイン後にコピー


接下来则是删除后续的部分,亦即: 192.168.1.100 Bcast:192.168.1.255 Mask:255.255.255.0

将 IP 后面的部分予以删除


[root@www ~]# /sbin/ifconfig eth0 | grep 'inet addr' | sed 's/^.*addr://g' | sed 's/Bcast.*$//g'
192.168.1.100
ログイン後にコピー


 

多点编辑

一条sed命令,删除/etc/passwd第三行到末尾的数据,并把bash替换为blueshell


nl /etc/passwd | sed -e '3,$d' -e 's/bash/blueshell/'
1  root:x:0:0:root:/root:/bin/blueshell
2  daemon:x:1:1:daemon:/usr/sbin:/bin/sh
ログイン後にコピー


-e表示多点编辑,第一个编辑命令删除/etc/passwd第三行到末尾的数据,第二条命令搜索bash替换为blueshell。

 

 

直接修改文件内容(危险动作)


sed 可以直接修改文件的内容,不必使用管道命令或数据流重导向! 不过,由於这个动作会直接修改到原始的文件,所以请你千万不要随便拿系统配置来测试! 我们还是使用下载的 regular_express.txt 文件来测试看看吧!

利用 sed 将 regular_express.txt 内每一行结尾若为 . 则换成 !


[root@www ~]# sed -i 's/\.$/\!/g' regular_express.txt
ログイン後にコピー


 

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


[root@www ~]# sed -i '$a # This is a test' regular_express.txt
ログイン後にコピー


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

sed 的『 -i 』选项可以直接修改文件内容,这功能非常有帮助!举例来说,如果你有一个 100 万行的文件,你要在第 100 行加某些文字,此时使用 vim 可能会疯掉!因为文件太大了!那怎办?就利用 sed 啊!透过 sed 直接修改/取代的功能,你甚至不需要使用 vim 去修订!

以上がsedの使い方を詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート