一、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
本文介绍使用grep、sed和awk等工具进行高效文本处理的方法,包括精确查找、替换和筛选数据等功能,帮助读者掌握实用的文本处理技能。
1291

被折叠的 条评论
为什么被折叠?



