Linux命令学习:sed

sed使用参数

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

动作说明: [n1[,n2]]function(增:a,i 改:c, s(查找替换) 删:d)动作需放在引号内
n1, n2 :不见得会存在,一般代表『选择进行动作的行数』,举例来说,如果我的动作是需要在 1020 行之间进行的,则『 10,20[动作行为] 』

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

将 /etc/passwd 的内容列出并且列印行号,同时,请将第 2~5 行删除:

[root@www ~]# nl /etc/passwd | sed'2,5d'
 
       

只要删除第 2 行:

nl /etc/passwd | sed'2d'

要删除第 3 到最后一行:

nl /etc/passwd | sed'3,$d'

在第二行后(亦即是加在第三行)加上『drink tea?』字样:

[root@www ~]# nl /etc/passwd | sed'2a drink tea'

那如果是要在第二行前:

nl /etc/passwd | sed'2i drink tea'

将第2-5行的内容取代成为『No 2-5 number』呢:

[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
6sync:x:5:0:sync:/sbin:/bin/sync

仅列出 /etc/passwd 文件内的第 5-7 行

[root@www ~]# nl /etc/passwd | sed -n '5,7p'

 
                                     

搜索 /etc/passwd有root关键字的行(要搜索时加上'/content/function'内容+操作)

nl /etc/passwd | sed'/root/p'1  root:x:0:0:root:/root:/bin/bash
1  root:x:0:0:root:/root:/bin/bash
 
                                       

如果root找到,除了输出所有行,还会输出匹配行,需要只输出匹配行,则加-n


搜索/etc/passwd,找到root对应的行,执行后面花括号中的一组命令,每个命令之间用分号分隔,这里把bash替换为blueshell,再输出这行:

nl /etc/passwd | sed -n '/root/{s/bash/blueshell/;p}'

 1  root:x:0:0:root:/root:/bin/blueshell

先观察原始信息,利用 /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:
 
                                             
 /sbin/ifconfig eth0 | grep'inet addr' | sed's/^.*addr://g' | sed's/Bcast.*$//g'

多点编辑

一条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 #直接修改文件而不输出到终端


你可能感兴趣的:(linux)