那我先建立一个测试的额数据
[root@g script]# cat example
101,John Doe,CEO
102,Jason Smith,IT Manager
103,Raj Reddy,Sysadmin
104,Anand Ram,Developer
105,Jane Miller,Sales Manager
[root@g script]#
首先说明一下sed的工作流程 sed读入一行放入模式空间(保留空间,在家里面有个百宝箱,你将自己的东西放进去) 后面再跟如命令。输出再讲模式空间清空。然后读入第二行一直读到最后。
当然第一步就是打印命令的实现:
1:用P来打印
[root@g script]# sed p example
101,John Doe,CEO
101,John Doe,CEO
102,Jason Smith,IT Manager
102,Jason Smith,IT Manager
103,Raj Reddy,Sysadmin
103,Raj Reddy,Sysadmin
104,Anand Ram,Developer
104,Anand Ram,Developer
105,Jane Miller,Sales Manager
105,Jane Miller,Sales Manager
[root@g script]#
当用P打印的话会输出2行
那怎样让他取消打印2行呢》》 用-n参数
#sed -n 'p' example
打印第一行或打印1-3行
[root@g script]#
[root@g script]# sed -n '1 p' example
101,John Doe,CEO
[root@g script]#
[root@g script]#
[root@g script]# sed -n '1,3 p' example
101,John Doe,CEO
102,Jason Smith,IT Manager
103,Raj Reddy,Sysadmin
用正则表达式结合sed 命令使用一定注意要注意模式 在‘’中加上// 如‘/Jason/ p’
打印Jason 所在行
[root@g script]# sed -n '/Jason/ p' example
102,Jason Smith,IT Manager
[root@g script]#
打印Jason至Jane所在的行
[root@g script]# sed -n '/Jason/,/Jane/ p' example
102,Jason Smith,IT Manager
103,Raj Reddy,Sysadmin
104,Anand Ram,Developer
105,Jane Miller,Sales Manager
打印以数字开头的所在行
[root@g script]# sed -n '/^[0-9]/ p' example
101,John Doe,CEO
102,Jason Smith,IT Manager
103,Raj Reddy,Sysadmin
104,Anand Ram,Developer
105,Jane Miller,Sales Manager
打印以Manage结尾的行
[root@g script]# sed -n '/Manager$/ p' example
102,Jason Smith,IT Manager
105,Jane Miller,Sales Manager
还可以结合标签使用,打印以数字开头,连续重复三次的行
[root@g script]# sed -n '/^[0-9]\{3\}/ p' example
101,John Doe,CEO
102,Jason Smith,IT Manager
103,Raj Reddy,Sysadmin
104,Anand Ram,Developer
105,Jane Miller,Sales Manager
[root@g script]#
隔一行打印一次
[root@g script]# sed -n '1~2 p' example
101,John Doe,CEO
103,Raj Reddy,Sysadmin
105,Jane Miller,Sales Manager
2:
删除命令d
和前面的一样;
删除出现 Developer出现的行
[root@g script]#
[root@g script]# sed '/Developer/ d ' example
101,John Doe,CEO
102,Jason Smith,IT Manager
103,Raj Reddy,Sysadmin
105,Jane Miller,Sales Manager
3:
连接命令
[root@g script]# sed -e '/Developer/ d' -e '/105/ d' example
101,John Doe,CEO
102,Jason Smith,IT Manager
103,Raj Reddy,Sysadmin
4:
神奇的替换命令
那先记个格式吧sed的替换格式是
sed 's///' example
中间家3个斜杠用来做替换
替换分为用
地址匹配和用
样式匹配的。
先来看看地址替换:
[root@g script]# sed '1 s/John/jesn/' example
101,jesn Doe,CEO
102,Jason Smith,IT Manager
103,Raj Reddy,Sysadmin
104,Anand Ram,Developer
105,Jane Miller,Sales Manager
样式替换:
[root@g script]#
[root@g script]# sed -n '/102/ s/Manager/jesn/p' example
102,Jason Smith,IT jesn
也可以两者结合更加精确:
[root@g script]#
[root@g script]# sed '1,/John/ s/CEO/CTO/' example
101,John Doe,CTO
102,Jason Smith,IT Manager
103,Raj Reddy,Sysadmin
104,Anand Ram,Developer
105,Jane Miller,Sales Manager
[root@g script]#
将替换的行写到另一个文件中去(仅仅是替换的行)
root@g script]# sed '1,/John/ s/CEO/CTO/w output.txt' example
101,John Doe,CTO
[root@g script]# cat output.txt
101,John Doe,CTO
全局替换 g:
[root@g script]# sed 's/1/CTO/' example
CTO01,John Doe,CEO
CTO02,Jason Smith,IT Manager
CTO03,Raj Reddy,Sysadmin
CTO04,Anand Ram,Developer
CTO05,Jane Miller,Sales Manag
g后面加上数字便是改行中所碰到的第几个
[root@g script]#
[root@g script]# sed 's/1/CTO/g2' example
10CTO,John Doe,CEO
102,Jason Smith,IT Manager
103,Raj Reddy,Sysadmin
104,Anand Ram,Developer
105,Jane Miller,Sales Manager
[root@g script]#
5:
不区分大小写的操作 i
[root@g script]# sed 's/jason/AAA/gi' example
101,John Doe,CEO
102,AAA Smith,IT Manager
103,Raj Reddy,Sysadmin
104,Anand Ram,Developer
105,Jane Miller,Sales Manager
[root@g script]#
6:将原串的数据加到replace的数据中去 &
[root@g script]# sed 's/jason/[&]/i' example
101,John Doe,CEO
102,[Jason] Smith,IT Manager
103,Raj Reddy,Sysadmin
104,Anand Ram,Developer
105,Jane Miller,Sales Manager
7:将前面开头的字符串都带个{};
[root@g script]# sed 's/^[0-9]\{3\}/{&}/' example
{101},John Doe,CEO
{102},Jason Smith,IT Manager
{103},Raj Reddy,Sysadmin
{104},Anand Ram,Developer
{105},Jane Miller,Sales Manager
8:sed直接将原文件就修改的 -i
[root@g script]# sed -i 's/john/jesn/i' example
[root@g script]# cat example
101,jesn Doe,CEO
102,Jason Smith,IT Manager
103,Raj Reddy,Sysadmin
104,Anand Ram,Developer
105,Jane Miller,Sales Manager
9:作业源文件替换成如下格式:
[101]
[102]
[103]
[104]
[105]
答案:
解法一:[root@g script]# sed 's/,.*//' example | sed 's/^[0-9]\{3\}/[&]/'
[101]
[102]
[103]
[104]
[105]
其中的第一个sed 将以逗号开头的后面所有用空格替换 那么
.* 就特别重要 表示
,后面有零个或多个字符 如果只跟* 的话那么只能替换出逗号;
解法二:
[root@g script]# sed 's/
\(^[0-9]*\)\(,.*\)/{
\1}/' example
{101}
{102}
{103}
{104}
{105}
红色标注的是使用标签进行替代。
解法三:
[root@g script]# sed 's
/\([^,]*\).*/[\1]/' example
[101]
[102]
[103]
[104]
[105]
红字表示的是以非,开头的进行匹配,则匹配到数字后就结束了。 则在打出.* 就是匹配全部 然后用标签\1 替代
10:截取ip地址:
解法一:使用cut
[root@g script]# ifconfig eth0 | grep 'inet addr' | cut -d: -f 2 | cut -d" " -f 1
8.8.8.2
解法二:使用sed
[root@g script]#
[root@g script]# ifconfig eth0 | sed -n '2 p' | sed 's/\([^0-9]*\)//' | sed 's/ .*//'
8.8.8.2
sed先找出那行,然后将非数字开头的用空格进行匹配,就把8.8.8.2开头的字幕匹配掉了。然后再以空格开始的用空格进行匹配掉
解法三:使用高端大气上档次的标签
[root@g script]# ifconfig eth0 | sed -n '2 p' | sed 's/\([^0-9]*\)\([0-9]\{1,3\}.[0-9]\{1,3\}.[0-9]\{1,3\}.[0-9]\{1,3\}\).*/\2/'
8.8.8.2
哈哈: 那就给你说下怎么解决的 ,首先依旧是将这行找到,然后将要匹配的东西在中间分成三个标签,然后将各个标签描述出来,最后只需打印出第二个标签就ok了。
inet addr:
8.8.8.2Bcast:8.8.8.255 Mask:255.255.255.0
就是只要求把蓝色的部分打出来就好了
解法四:awk
[root@g script]#
[root@g script]# ifconfig eth0 | sed -n '2 p' | awk -F":" '{print $2}' | awk -F" " '{print $1}'
8.8.8.2
11:去除注释和空行:
解法一:
[root@g script]# sed 's/#.*//' my.cnf | sed '/^$/ d'
[client]
port = 3306
socket = /tmp/mysql.sock
[mysqld]
port = 3306
socket = /tmp/mysql.sock
skip-locking
key_buffer = 16M
max_allowed_packet = 1M
table_cache = 64
sort_buffer_size = 512K
net_buffer_length = 8K
^$表示空行
11:追加命令 a
在第二行后添加一行
[root@g script]# sed '2 a 203,ridy,R&D' example
101,jesn Doe,CEO
102,Jason Smith,IT Manager
203,ridy,R&D
103,Raj Reddy,Sysadmin
104,Anand Ram,Developer
105,Jane Miller,Sales Manager
在行尾添加一行
[root@g script]# sed '$ a 205,nihao salesman' example
101,jesn Doe,CEO
102,Jason Smith,IT Manager
103,Raj Reddy,Sysadmin
104,Anand Ram,Developer
105,Jane Miller,Sales Manager
205,nihao salesman
在后面添加多行
[root@g script]# sed '/jesn/ a\
> 201 nihao ,smith\
> 202 nihao ,jnny
> ' example
101,jesn Doe,CEO
201 nihao ,smith
202 nihao ,jnny
102,Jason Smith,IT Manager
103,Raj Reddy,Sysadmin
104,Anand Ram,Developer
105,Jane Miller,Sales Manager
在前面添加多行 i
[root@g script]#
[root@g script]# sed '/jesn/ i\
201 nihao ,smith\
202 nihao ,jnny
' example
201 nihao ,smith
202 nihao ,jnny
101,jesn Doe,CEO
102,Jason Smith,IT Manager
103,Raj Reddy,Sysadmin
104,Anand Ram,Developer
105,Jane Miller,Sales Manager
12:change改变更改命令: c
[root@g script]#
[root@g script]# sed '/jesn/ c ridy' example
ridy
102,Jason Smith,IT Manager
103,Raj Reddy,Sysadmin
104,Anand Ram,Developer
105,Jane Miller,Sales Manager
13:打印行号:
[root@g script]# sed '/jesn/ = ' example
1
101,jesn Doe,CEO
102,Jason Smith,IT Manager
103,Raj Reddy,Sysadmin
104,Anand Ram,Developer
105,Jane Miller,Sales Manager
14:字符转换:y///
[root@g script]# sed 'y/j/J/' example
101,Jesn Doe,CEO
102,Jason Smith,IT Manager
103,RaJ Reddy,Sysadmin
104,Anand Ram,Developer
105,Jane Miller,Sales Manager
15:退出命令,当读到第5行时让他退出 q
[root@g script]# sed '3 q' example
101,jesn Doe,CEO
102,Jason Smith,IT Manager
103,Raj Reddy,Sysadmin