1 grep 搜索关键字
全局搜索正则表达式
1.1 基本格式
grep root passwd #过滤含有root关键字

-e 多个过滤词
grep -e root -e bash pa
grep -E "root|bin" pa # 等同于上面的命令

-i 忽略大小写

-E 过滤
grep -E "\<root" passwd ##root字符之前不能有字符
grep -E "root\>" passwd ##root字符之后不能有字符

-v 反向过滤

grep -数字 ##显示过滤行以及上面几行和下面几行
grep -n ##显示匹配的行所在行号
grep -A ##显示过滤行以及下面几行
grep -B ##显示过滤行以及上面几行

^westos以westos开有
westos$ 以westos结尾

1.2 字符匹配
w....s ##w开头s结尾中间4个任意字符
.....s ##s结尾前面5个任意字符
* ##字符出现任意

+ ##1次到任意次


{n} ##n此
{m,n} ##m到n次
{0,n} ##0-n次
{,n} ##0-n次
{m,} ##最少m次
(lee){2} ##lee字符串出现2次

2 sed 流编辑器
sed 参数 命令 处理对象
sed 参数 处理对象 -f 处理规则文件
2.1 p 显示
sed -n 5p westos ##显示第五行
sed -n 3,5p westos ##显示3到5行
sed -ne "3p;5p westos ##显示3和5行
sed -ne 1,5p westos ##1-5行
sed -ne '5,$p' westos ##5到最后以行
sed -n '/^#/p' fstab ##显示以#开头的行

2.2 d 删除
sed 5d westos ##删除第五行
sed '/^#/d' fstab ##把#开头的行删除
sed '/^UUID/!d' fstab ##除了UUID以外的行都删除
sed -e '5,$d' westos ## 同时操作第5行和最后一行

2.3 a 添加
sed '1ahello' fstab # 在第一行后面添加

sed '/^UUID/a666' fstab # 符合要求的行添加

sed '/^UUID/a6\n66' fstab # 换行添加

2.4 i 插入
sed '1ihello' fstab

2.5 w 输出重定向
sed '/^UUID/w westofile' westos ##把westos中UUID开头的行写入westosfile中

2.6 r 合并文件

2.7 s 替换
2.7.1 普通替换
sed 's/bin/6666/g' passwd # 替换bin为6666



2.7.2 转义字符替换
sed 's/\//???/g' passwd
sed 's@/@???@g' passwd # 两条命令是等效的

2.8 f 执行文件中多条命令
sed -f rule fstab

3 awk 报告生成器
截取所需要的数据
3.1 显示列
awk -F : '{print $0}' passwd
awk -F : '{print $1}' passwd
awk -F : '{print $1,$7}' passwd # 显示第一列和第7列

3.2 条件
awk -F : '/^root/{print $1,$7}' passwd # // 里面的内容是条件判断
awk -F : '/^root/||/^lp/{print}' passwd # 或者
awk -F : '/^root/&&/bash$/{print}' passwd # 并且

awk -F : '/bash$/{print NR}' passwd # 行
awk -F : '/bash$/{print $NF}' passwd # 列

awk -F : 'BEGIN{N=0}/bash$/{N++}END{print N}' passwd

awk -F : '$3!~/^0/&&/bash$/{print}' passwd # 第三列,以0开头,去掉后,并且剩余的行结尾是bash

4 编写脚本
4.1 请显示系统中能被su命令切换的用户名称
grep -E "\<bash$|\<sh$" /etc/passwd

4.2 请显示网卡IP
ifconfig ens160 | awk '/inet\>/{print $2}'




















