一、grep命令的基本使用方法及常用参数介绍
grep [全称:Globally search a Regular Expression and Print 全局搜索正则表达式并打印 ]
grep 命令格式
grep 匹配条件 处理文件
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 | 反向过滤 |
(egrep = grep -E)
二、greo命令匹配字符个数的规则
grep 搜索字符数量匹配规则
^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次 |
{m,} | 最少m次 |
(lee){2} | lee字符串出现2次 |
grep 脚本代码
要求,统计系统当中能够被操作者使用的用户个数
用grep过滤出 /etc/passwd 文件中以bash或sh结尾的行(并且前面不能带字符),再用管道符总结多少行
三、sed命令的使用方法
开启sed流编辑器以后,它会把我们要处理对象的所有内容加载到内存的模式空间里面,然后逐行处理,符合条件的行会进行操作,不符合条件行的直接显示
sed 命令格式
命令格式:
sed 参数 命令 处理对象
sed 参数 处理对象 -f 处理规则文件
p | 显示 |
---|---|
sed -n 5p | 显示第五行 |
sed -n 3,5p | 显示3到5行 |
sed -ne "3p;5p | 显示3和5行 |
sed -ne 1,5p | 1-5行 |
sed -ne ‘5,$p’ | 5到最后以行 |
sed -n ‘/^#/p’ | 显示以#开头的行 |
d | 删除 |
---|---|
sed 5d | 删除第五行 |
sed ‘/^#/d’ fstab | 把#开头的行删除 |
sed ‘/^UUID/!d’ fstab | 除了UUID以外的行都删除 |
a | 添加 |
---|---|
sed -e ‘2a hello westsos’ | 第二行后添加hello westos |
sed -e ‘$a hello westos’ | 最后一行后面添加 hellowestos |
sed -e ‘/^#/a hello westos’ | #开头的行每一行后面都加 hello westos |
w | 把符合的行写到指定文件中 |
---|---|
sed ‘/^UUID/w westofile’ westos | 把westos中UUID开头的行写入westosfile中 |
i | 插入 |
---|---|
sed ‘5ihello westos’ | 在第五行前面插入 hello westos |
r | 整合文件 |
---|---|
sed ‘5r 文件2’ 文件1 | 将文件2整合 加到文件1第五行后面 |
替换
sed ‘s/:/###/g’ passwd 全文的 : 替换为###
s表示每一行 g表示每一列
也可以将引号以内的规则写成文件
vim rule
然后输入命令
sed -f 策略文件 处理的文件
sed -f rule fstab
四、awk报告生成器的用法
awk -F 分隔符 BEGIN{ }{ }END{ } FILENAME
生成第一列报告
awk -F : ‘{print $1}’ passwd
-F表示指定分隔符
$0 #所有的列
$1 #第一列
$2 #第二列
$3 #第三列
还可与加上数据的过滤
以root开头的行
awk -F : ‘/^root/{print $0}’ passwd
增添的参数
/条件1|条件2/ ## 条件1或者条件2
/条件1/||/条件2/ ##条件1或者条件2
/条件1/&&/条件2/ ##条件1并且条件2
| / || 表示或者
&&表示并且
NR #行数
NF #列数
BEGIN 表示动作开始前做什么
awk -F : ‘BEGIN{print ‘start’}/bash$/{print $0}’ passwd
打印start关键字
westos #westos变量值
“westos” #westos字符串
统计以bash结尾的行数
统计第六行为home
awk -F : ‘$6~/home/{ print $0}’ passwd
统计第六行不为home
书写抓取ip需求
输入ifconfig ens160 命令 是查询ens160网卡的命令
用管道符 | 导出来
再用awk生成报告信息
/inet>/查找inet的信息并且inet是后面不能带字符的
$2 表示第二列
print表示显示出来