2.文本处理工具

1.grep

grep = [Globally search a Regular Expression and Print]
grep -E = egrep

1.grep 格式##

grep 匹配条件 处理文件
grep root passwd过滤root关键字
grep -i root passwd后略大小写
grep -E “<root” passwdroot字符之前不能有字符
grep -E “root>” passwdroot字符之后不能有字符
grep -数字显示过滤行以及上面几行和下面几行
grep -n显示匹配的行所在行号
grep -A显示过滤行以及下面几行
grep -B显示过滤行以及上面几行
grep -v反向过滤
grep字符数量匹配规则
^westos以westos开有
westos$以westos结尾
w…sw开头s结尾中间4个任意字符
…ss结尾前面5个任意字符
*字符出现任意
?0到1次
+1次到任意次
{n}n次
{m,n}m到n次
{0,n}0-n次
{,n}0-n次
{m,}最少m次
(lee){2}lee字符串出现2次

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

练习脚本:
请显示系统中能被su命令切换的用户名称
grep -E “bash ∣ s h |sh sh” /etc/passwd | cut -d : -f 1

2.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到最后1行
sed -n ‘/^#/p’ fstab显示以#开头的行
d删除
sed 5d westos删除第五行
sed ‘/^#/d’ fstab把#开头的行删除
sed ‘/^UUID/!d’ fstab除了UUID以外的行都删除
sed -e ‘5,$d’ westos五行以后都删掉
a添加
sed -e ‘$a hello world’ fstab末尾添加hello world
sed -e ‘$a hello\nworld’ fstab末尾添加hello后换行添加world
sed -e ‘/^#/a hello world’ fstab所有#开头的行后添加一行hello world
c替换
sed -e ‘/^#/c hello world’ fstab##开头的行换为hello world
sed ‘5chello world’ westos第五行替换为hello world
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为关闭状态
例如:
sh Apache_port.sh
ERROR: Pleaase input port number following script !!
sh Apache_port.sh 8080
apache的端口会被修改为8080

 #/bin/bash
 setenforce 0
 [ -z $1 ] && {
 echo -e "请写上端口号"
 exit
 }
 rpm -q httpd &> /dev/null &&{
 echo "服务已安装"
 } || {
 echo -e "请安装httpd服务"
 }
 sed   " /^Listen/c Listen $1 " -i /etc/httpd/conf/httpd.conf
 firewall-cmd --permanent --add-port=$1/tcp
 firewall-cmd --reload
 systemctl restart httpd
 echo "设置成功!!!"

3.awk

awk -F 分隔符 BEGIN{ } { }END{ } FILENAME

NR行数
NF列数
FILENAME文件名称本身
westoswestos变量值
“westos”westos字符串
/bash$/条件
/条件1条件2/
/条件1/
/条件1/&&/条件2/条件1并且条件2
$0所有的列
$1第一列
$2第二列
$3第三列

/etc/passwd文件的第六列没有home关键字并且以bash结尾的行
awk -F : ‘KaTeX parse error: Expected 'EOF', got '&' at position 10: 6!~/home/&̲&/bash/{print}’ /etc/passwd

4测试

1.统计在系统中能su切换的并且用户加目录不在/home下的用户数量

awk -F : ‘BEGIN{n=0}KaTeX parse error: Undefined control sequence: \/ at position 6: 6!~/^\̲/̲home/&&/bash|sh$/{print $0;n++}END{print n}’ passwd

2.过滤ens3的ip

ifconfig ens3 | awk ‘/inet>/{print $2}’
172.25.254.118

3.查找访问apache最多的ip

awk ‘{print $1}’ /etc/httpd/logs/access_log | sort -n | uniq -c | sort -t " " -k 2 -rn | head -n 1 | awk ‘{print $2}’

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

热到想喝冰阔落

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值