1.sed命令
sed:stream editor :一次处理一行内容,处理时,把当前的行存储在临时缓冲区,处理完后,输送到屏幕,不加参数的情况下sed命令不会改变源文件内容,sed命令用法如下:
sed [参数] '命令' file
1).模式:
p ##显示
d ##删除
a ##添加
c ##替换
i ##插入
2).参数:
-n ##只输出处理后的结果
-i ##处理并修改源文件
首先,我们看到 /etc/fstab中的源文件内容如下:
sed -n ‘/:/p’ /etc/fstab ##显示有:的行
sed -n ‘/^#/p’ /etc/fstab ##显示以#开头的行
sed -n ‘/2014$/p’ /etc/fstab ##显示以2014结尾的行
sed -n ‘/2014$/!p’ /etc/fstab ##显示所有不以2014结尾的行
sed -n ‘2,6p’ /etc/fstab ##显示第2到第6行
sed ‘/^UUID/d’ /etc/fstab ##显示除了以UUID开头的行之外的所有行
sed ‘/^$/d’ /etc/fstab ##显示除了空行之外的所有行
sed ‘1,4d’ /etc/fstab ##显示除了1到4行之外的所有行
sed ‘/Hello/aWorld’ westos ##在Hello行后再添加一行World
sed ‘s/Hello/hello world/g’ westos ##将Hello替换为hello world
sed ‘s/Hello/hello\nworld/g’ westos
sed ‘s///#/g’ /etc/fstab ##将fstab中所有/替换为#
sed ‘/Hello/chello world’ westos ##将Hello替换为hello world
sed ‘/Hello/iworld\nwestos’ westos
-i:改变原文件内容
首先源文件内容如下:
sed -i ‘s/westos/redhat/’ passwd ##只替换第一行匹配到的第一个字符
sed -i ‘s/westos/redhat/g’ passwd ##全局替换
2.awk命令
awk处理机制:根据模式一次从文件中抽取一行文本,对这行文本进行切片(默认使用空白字符作为分隔符).
[root@server shell-script ]# cat test
this | is | a | file
$1 $2 $3 $4
awk ‘{print $n}’ test ##$n表示输出第n个字段
awk -F “:” ‘{print $1,$3}’ test ##指定分隔符,输出第1和3列
passwd源文件如下:
awk ‘{print FILENAME,NR}’ /etc/passwd ##输出文件名,和当前操作的行号
awk -F: ‘{print NR,NF}’ /etc/passwd ##输出每次处理的行号,以及当前以":"为分隔符的字段个数
BEGIN{}:读入第一行文本之前执行的语句,一般用来初始化操作
{}:逐行处理
END{}:处理完最后以行文本后执行,一般用来处理输出结果
awk -F: 'BEGIN{print "REDHAT"} {print NR;print } END {print "WESTOS"}' passwd ##文件开头加REDHAT,末尾加WESTOS,打印行号和内容
awk '/bash$/{print}' passwd ##输出以bash结尾的
awk 'NR==3 {print}' passwd ##输出文件第三行
源文件passwd1内容如下:
awk 'NR % 2 == 0 {print}' passwd1 ##偶数行
awk 'NR % 2 == 01{print}' passwd1 ##偶数行
awk 'NR >=3 && NR <=5 {print }' passwd1 ##第3到5行
awk ‘BEGIN{i=0}{i+=NF}END{print i}’ passwd1 ##统计文本总字段个数
#if单分支语句
awk -F: 'BEGIN{i=0}{if($7~/bash$/){i++}}END{print i}' /etc/passwd ##统计登录shell为bash的用户
#if双分支
awk -F: 'BEGIN{i=0;j=0}{if($3<=500){i++}else{j++}}END{print i,j}' /etc/passwd ##统计uid小于等于500和大于500的用户个数
#for循环
awk 'BEGIN{for(i=1;i<=5;i++){print i}}' ##输出1到5