一、grep
grep
grep -E = egrep
grep 格式
grep 匹配条件 处理文件
grep root passwd | 过滤root关键字 |
grep ^root passwd | 以root开头 |
grep root$ passwd | 以root结尾 |
grep -i root passwd | 忽略大小写 |
grep -E "\<root" passwd | root字符之前不能有字符 |
grep -E "root\>" passwd | root字符之后不能有字符 |
grep -数字 | 显示过滤行以及上面几行和下面几行 |
grep -n | 显示匹配的行所在行号 |
grep -A | 显示过滤行以及下面几行 |
grep -B | 显示过滤行以及上面几行 |
grep -v | 反向过滤 |
^westos | 以westos开头 |
westos$ | 以westos结尾 |
w....s | w开头s结尾中间4个任意字符 |
.....s | s结尾前面5个任意字符 |
* | 字符出现任意 |
? | 0到1次 |
+ | 1次到任意次 |
{n} | n次 |
{m,n} | m到n次 |
{0,n} | 0-n次 |
{,n} | 0-n次 |
{m,} | 最少m次 |
(lee){2} | lee字符串出现2次 |
练习脚本:
请显示系统中能被su命令切换的用户名称
#!/bin/bash
grep -E "$(cat /etc/shells)" /etc/passwd | cut -d : -f 1
二、sed
命令格式:
sed 参数 命令 处理对象
sed 参数 处理对象 -f 处理规则文件
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 | 显示以#开头的行 |
d | 删除 |
sed 5d westos | 删除第五行 |
sed '/^#/d' fstab | 把#开头的行删除 |
sed '/^UUID/!d' fstab | 除了UUID以外的行都删除 |
sed -e '5,$d' westos | |
-e 多行策略 |
a | 添加 |
sed -e '$a hello world' fstab | |
sed -e '$a hello\nworld' fstab | |
sed -e '/^#/a hello world' fstab |
c | 替换 |
sed -e '/^#/c hello world' fstab | |
sed '5chello world' westos |
w | 把符合的行写到指定文件中 |
sed '/^UUID/w westofile' westos ##把westos中UUID开头的行写入westosfile中 |
i | 插入 |
sed '5ihello westos' westos |
r | 整合文件 |
sed '5r haha' westos |
sed | 字符替换 |
sed 's/:/###/g' westos | |
sed 's/:/###/' westos | |
sed 's/:/###/g' westos | |
sed '1,5s/:/###/g' westos | |
sed '1s/:/###/g' westos | |
sed '1s/:/###/g;5s/:/###/g' westos | |
sed '/lp/,/shutdown/s/:/###/g' westos | |
sed 's/\//####/g' westos | |
sed 's@/@####@g' westos |
sed 's@/@####@g' -i westos 把sed处理的内容保存到westos文件中
练习及脚本
Apache_port.sh
此脚本后介入数字
http的端口就改为此数字
假设selinux为关闭状态
#!/bin/bash
[ -z $1 ] && {
echo -e "\033[31mError:Please input port following script\033[0m"
exit
}
rpm -q httpd &> /dev/null || {
echo -e "\033[31mError:Apache is not installed !! \033[0m"
exit
}
[ "$USER" != "root" ] && {
echo -e "\033[31mError:Please run script with root !!\033[0m"
exit
}
netstat -antlpue | grep -E ":$1\>" &> /dev/null &&{
echo -e "\033[31mError:Port $1 is in used !!\033[0m"
exit
}
sed "/^Listen/cListen $1" -i /etc/httpd/conf/httpd.conf
systemctl restart httpd
三、awk
wk:报告生成器
处理机制:awk会逐行处理文本,支持在处理第一行之前做一些准备工作,以及在处理完最后一行做一些总结性质的工作,在命令格式上分别体现如下
BEGIN{}:读入第一行文本之前执行,一般用来做初始化操作
{}: 逐行处理,逐行读入文本执行相应的处理,是最常见的编辑指令块
END{}:处理完最后一行文本之后执行,一般用来输出处理结果
awk -F 分隔符 BEGIN{}{}END{} FILENAME
NR #行数
NF #列数
FILENAME #文件名称本身
westos #westos变量值
“westos” #westos字符串
/bash$/ #条件
/条件1|条件2/ #条件1或者条件2
/条件1/||/条件2/ #条件1或者条件2
/条件1/&&/条件2/ #条件1并且条件2
$0 #所有的列
$1 #第一列
$2 #第二列
$3 #第三列
#/etc/passwd文件的第六列没有home关键字并且以bash结尾的行
awk -F : '$6!~/home/&&/bash$/{print}' /etc/passwd
课后练习:
1、抓取主机ip的方法:
2、统计杂在系统中能su切换的并且用户加目录不在/home下的用户数量
awk -F : 'BEGIN{n=0}$6~/home/&&/bash$/{n++}END{print n}' /etc/passwd