sed是一种流编辑器,它是文本处理中很是中的工具,可以完美的配合正则表达式使用,功能不一样凡响。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并无 改变,除非你使用重定向存储输出。Sed主要用来自动编辑一个或多个文件;简化对文件的反复操做;编写转换程序等。linux
命令格式正则表达式
sed [options] 'command' file(s) sed [options] -f scriptfile file(s)
经常使用选项:编辑器
-n∶使用安静(silent)模式。在通常 sed 的用法中,全部来自 STDIN的资料通常都会被列出到萤幕上。但若是加上 -n 参数后,则只有通过sed 特殊处理的那一行(或者动做)才会被列出来。 -e∶直接在指令列模式上进行 sed 的动做编辑; -f∶直接将 sed 的动做写在一个档案内, -f filename 则能够执行 filename 内的sed 动做; -r∶sed 的动做支援的是延伸型正规表示法的语法。(预设是基础正规表示法语法) -i∶直接修改读取的档案内容,而不是由萤幕输出。
经常使用命令:工具
a ∶新增, a 的后面能够接字符串,而这些字符串会在目前的下一行出现。 c ∶取代, c 的后面能够接字符串,这些字符串能够取代 n1,n2 之间的行。 d ∶删除,后面不接任何东西; i ∶插入, 与a只有一点不一样,增长的字符串会在目前的上一行出现; p ∶列印,亦即将某个选择的资料印出。在使用p的时候通常会加上-n参数。 s ∶取代,能够直接进行取代的工做。
删除某行 $ sed '1d' filename 删除第一行 $ sed '$ d' filename 删除最后一行 $ sed '1,2d' filename 删除第一行到第二行 $ sed '2,$ d' filename 删除第二行到最后一行
显示某行 $ sed -n '1p' filename 显示第一行 $ sed -n '$ p' filename 显示最后一行 $ sed -n '1,2p' filename 显示第一行到第二行 $ sed -n '2,$ p' filename 显示第二行到最后一行 使用模式进行查询 $ sed -n '/world/p' filename 查询包括关键字world所在全部行 $ sed -n '/\$ /p' filename 查询包括关键字$ 所在全部行,使用反斜线\屏蔽特殊含义
[root@localhost ~]# cat filename Hello! world! end [root@localhost ~]# sed '1a people' filename 第一行后增长字符串"people" Hello! people world! end [root@localhost ~]# sed '1,3a people' filename 第一行到第三行后增长字符串"people" Hello! people world! people end people [root@localhost ~]# sed '1i people\nperson' filename 第一行前增长多行,使用换行符\n people person Hello! world! end
[root@localhost ~]# cat filename Hello! world! end [root@localhost ~]# sed '1c Hi' filename Hi world! end [root@localhost ~]# sed '1,2c Hi' filename Hi end
格式:sed 's/要替换的字符串/新的字符串/g' 修改的文件 [root@localhost ~]# cat filename Hello! world! end [root@localhost ~]# sed -i 's/Hello!/start/g' filename 把Hello!替换为start [root@localhost ~]# cat filename start world! end [root@localhost ~]# cat filename start world! end [root@localhost ~]# sed -i '$a bye' filename 在最后一行后面新加bye($表明最后同样,a表示在当前行下一面添加,bye是新加内容,中间有没有空格都行) [root@localhost ~]# cat filename start world! end bye
awk其名称得自于它的创始人 Alfred Aho 、Peter Weinberger 和 Brian Kernighan 姓氏的首个字母。实际上 AWK 的确拥有本身的语言: AWK 程序设计语言 , 三位建立者已将它正式定义为“样式扫描和处理语言”。它容许您建立简短的程序,这些程序读取输入文件、为数据排序、处理数据、对输入执行计算以及生成报表,还有无数其余的功能。spa
awk 是一种很棒的语言,它适合文本处理和报表生成,其语法较为常见,借鉴了某些语言的一些精华,如 C 语言等。在 linux 系统平常处理工做中,发挥很重要的做用,掌握了 awk将会使你的工做变的高大上。 awk 是三剑客的老大,利剑出鞘,必会不一样凡响。设计
一、首先咱们看一下经常使用的cut命令的基本使用方法,cut英文意思是切,它的功能和和awk基本相同,惟一不一样的是awk能够说是cut的plus版本(但不是一个厂家)。blog
cut -d(指定以什么为分割符) -f(指定列) 第一列 #cut -d ‘ ’ -f 5
cut没法切割以空格为分割符的数据。排序
二、awk的基本经常使用写法ip
awk ‘条件一{动做一}条件二{动做二} ’ 文件 固然咱们也可用使用管道符|awk。。。。。
三、awk的基本写法字符串
#咱们使用printf的话最后必需要加上\n换号符号,$数字是表示第几列 df -h | awk '{printf $1 "\t" $5 "\n"}' #若是使用print的话就不须要再多写一个\n了 df -h | awk '{print $1 "\t" $5}' #注意,为了避免想让两行数据黏在一块儿,因此中间须要用“\t”空格符隔开。最外面的必须是单引号,而里面的\t和\n必须使用双引号。
四、实例
咱们想试试判断linux的根分区的使用状况,或者是某个分区的使用状况,咱们怎么判断呢。
#df -h | grep sda3 | awk '{print $5}' | cut -d '%' -f 1 解释: df -h | grep sda3是个人根分区,awk抓取第五列,也就是拿到6%这个数字,可是不想要百分号,那咱们在用cut切一下,就OK了
五、BEGIN(实际上就是在打印结果的开始打印里面动做的一句话)
#df -h | grep sda3 | awk 'BEGIN{print "This is the use of the root partition"}{print $5}' | cut -d '%' -f 1
BEGIN的关键用法。
#awk '{FS=":"}{print $1 "\t" $3}' /etc/passwd
#awk 'BEGIN{FS=":"}{print $1 "\t" $3}' /etc/passwd
关键:咱们知道awk是每次提取的时候都是先读取第一行后,才开始执行后面的动做语句,因此第一行没有被处理。这个时候就须要使用BEGIN,这个时候它就会处理全部数据。
END的用法
有BEGIN固然就有END了
#awk 'END{print"END!!!"}{print $1 "\t" $3}' /etc/passwd #和BEGIN的用法基本相同,只不过是在处理数据动做的最后加打印而已。
六、关系运算符
关系运算符 > 大于 < 小于 = 等于 #这里的等于就把结果都改为这等于后面的数值,以下图 >= 大于等于 <= 小于等于