Linux三剑客-sed&awk

一、三剑客-sed命令

1、格式

sed + '找谁干啥' + 文件

找谁:条件,匹配哪一行,哪些行.
干啥:动作,增删改查.
#显示文件的第3行
sed -n '3p' /etc/passwd
选项说明
-n取消默认输出
-p查找
-rsed支持扩展正则
-i修改文件内容,这个选项放在最后
-i.bak先进行备份,然后修改文件内容,这个选项放在最后

2、如何运行

在这里插入图片描述

3、sed之查找

一种是类似于grep模糊查找. 一种是精确查找,行号.

  • 类似于grep命令的过滤,比grep强在于可以指定行号,
  • 类似于grep命令的功能,模糊查询(通过正则).

案例01:取出文件的第3行

-n表示取消默认输出,sed处理文件的时候会默认的输出每一行内容

sed -n '3p' /etc/passwd

案例02:取出/etc/passwd的第2行到第5行

sed -n '2,5p' /etc/passwd

案例03:过滤出/etc/passwd中包含root的行

sed -n '/root/p' /etc/passwd
cat /etc/passwd | grep root
#如果是以root开头呢
sed -n '/^root/p' /etc/passwd

sed进行过滤的时候需要使用//并且里面支持基础正则 如果需要使用扩展正则需要使用sed -r选项

案例04:获取范围内的日志

#sed -n '/从哪里来/,/到哪里去/p' tx.txt
sed -n '/102/,/104/p' tx.txt

案例05:只显示第3行和第5行

sed -n '3p;5p' /etc/passwd

案例06:表示有规律查找

 [root@yunwei ~]# seq 10 | sed -n '1~2p'
1
3
5
7
9
[root@yunwei ~]# seq 10 | sed -n '2~2p'
2
4
6
8
10

4、sed之修改

sed命令替换格式

sed 's#找谁#替换成什么#g' tx.txt

推荐使用:###,@@@,///

s substitute 替换 sub

g global 全局替换,这一行中把所有匹配到的内容都进行替换,否则只替换每一行第1个匹配的内容

修改文件内容

-i确认修改

修改文件内容之前进行备份,然后修改文件内容

sed -i.bak 's#js#xp#g' tx.txt

一般用于替换某一个文件,如果是多个文件就打包压缩进行备份即可

后向引用格式

sed命令中用于处理列的方式:

使用替换的形式 s###g

前2个井号之间通过正则与(),对数据进行分组

后面2个井号之间通过\数字,去调用前面分组的内容

#输出12345678,通过sed加工变成1<234567>8
[root@yunwei ~]# echo {1..8} | sed -r 's#(1)(.*)(8)#\1<\2>\3#g'
1< 2 3 4 5 6 7 >8

案例01:调换/etc/passwd第1列和最后一列内容

sed -r 's#(^.*)(:x.*:)(.*$)#\3\2\1#g' passwd 

案例02:取出网卡ip地址

ip a s eth0 | sed -n '3p'  | sed -r 's#^.*et ([0-9.]+)/.*$#\1#g'

5、sed之删除

d delete 删除sed命令删除功能按照行为单位进行

如果仅仅删除某一行的一些字符推荐使用's#[a-z]##g'

排除/删除文件中的空行和带注释的行

egrep -v '^$|^#' sshd_config
sed -r '/^$|^#/d' sshd_config
awk '! /^$|^#/' sshd_config

6、sed之增加

cai

  • a append 在指定行后面追加内容
  • i insert 在指定行上面插入一行
  • c replace 替换指定行的内容
[root@yunwei ~]# cat tx.txt
101,aa,CEO
102,bb,CTO
103,cc,COO
104,js,CFO
105,time,CIO
110,gege,COCO
[root@yunwei ~]# sed '3a tianjia' tx.txt
101,aa,CEO
102,bb,CTO
103,cc,COO
tianjia
104,js,CFO
105,time,CIO
110,gege,COCO
[root@yunwei ~]# cat tx.txt
101,aa,CEO
102,bb,CTO
103,cc,COO
104,js,CFO
105,time,CIO
110,gege,COCO
#只要不保存,就不加一个 -i

7、总结

在这里插入图片描述

二、三剑客-awk命令

四剑客特点擅长
find查找文件查找文件,与其他命令配合
grep/egrep过滤过滤速度很快
sed过滤,取行,替换,删除替换,修改文件内容,取行
awk过滤,取行,取列,统计计算,判断,循环…取行,取列,统计计算

1、格式

#取出/etc/passwd中的第1行的第1列,第3列和最后一列
awk -F: 'NR =1{print $1,$3,$NF}' /etc/passwd
awk 选项 '条件{动作}' /etc/passwd
#条件 找谁
#动作 干啥

2、执行流程

在这里插入图片描述

3、取行

案例一:取出/etc/passwd的第1行

[root@yunwei ~]# awk 'NR==1' /etc/passwd
[root@yunwei ~]# awk 'NR==1{print $0} ' /etc/passwd
root:x:0:0:root:/root:/bin/bash

NR Number of Record 记录号,行号

== 表示等于

{print $0} 输出整行内容 $0表示当前行的内容、awk满足条件后默认的动作,输出这一行的内容

案例二:取出/etc/passwd的第2行到第5行的内容

awk 'NR>=2 && NR<=5' /etc/passwd

>= 表示大于等于

&& 表示并且

|| 表示或者

awk常用运算符说明
==等于
!=不等于
>大于
>=大于等于
<小于
<=小于等于
&&并且

案例三:过滤出/etc/passwd文件中包含root或nobody的行

awk '/root/ || /nobody/' /etc/passwd
awk '/root|nobody/' /etc/passwd

案例四:从包含root的行到包含nobody的行

awk '/root/,/nobody/' /etc/passwd

4、取列

案例一:使用awk取出 ls -lh 的大小列和最后一列

 ls -lh | awk '{print $5,$9}'| column -t

awk中取列的时候说明:

  • 数字,表示取列,数字,表示取列,数字,表示取列,1 第1列; $0表示这一行.
  • $NF 最后一列
  • NF Number of Field 每行有多少列
  • $(NF-1) 取出倒数第2列,一般用于正向取发生变化或数字过大.

awk输出与对齐:

  • 使用column -t 命令即可或者使用 \t

案例二:取出/etc/passwd中的第1列,第3列和最后一列

awk取列的时候,默认是通过空白字符进行分割的.

空白字符:空格,连续空格,tab键.

但是一些时候使用默认分隔符不够了,需要我们手动指定分隔符,通过-F选项指定. 未来我们想快速取出想要的内容,选择趁手工具(选好分隔符).

选择分隔符建议: 看你目标两边是啥

awk -F':'  '{print$1,$3,$NF}' /etc/passwd | column -t

案例三:指定复杂分隔符取出 ip

ip a s eth0 | awk 'NR==3'| awk '{print $2}' | awk -F '/' '{print$1}'
#不加-F指定分隔符,按照直意理解
ip a s eth0 | awk -F '[ /]' 'NR==3{print $6}'
ip a s eth0 | awk -F '[ /]+' 'NR==3{print $3}'
#+号 连续的空格

在这里插入图片描述

5、取行和取列

awk 格式'条件{动作}

案例一:取行+取列 取ip地址

ip a s eth0 | awk -F '[ /]+' 'NR==3{print $3}'

案例二:取出权限部分 stat /etc/hosts的0644部分

stat /etc/hosts | awk -F '[(/]' 'NR==4{print $2}'

案例三:取出/etc/passwd文件中第3列大于100的行,取出这行的第1列,第3列和最后列

awk -F ':' '$3>=1000{print $1,$3,$NF}' /etc/passwd | column -t

通过awk实现对某一列进行判断,然后进行提取.

案例四:如果系统swap使用超过0则输出"异常系统开始占用swap

free | awk 'NR==3 && $3>0{print "异常系统开始占用swap"}'

案例五:过滤出/etc/passwd第4列的数字是以0或1开头的行,输出第1列,第3列,第4列

awk -F ':' '$4~/^[01]/{print $1,$3,$4}' /etc/passwd

温馨提示 awk中 通过~可以实现对某一列进行过滤 某一列中含有xxxx内容

  • ~ 表示包含的意思 $1 ~ /root/ 表示第1列中包含root
  • !~表示不包含

6、awk的统计与计算

awk进行统计有2类案例:

  • 类似于wc -l统计次数.
  • 进行求和,累加.

案例一:统计次数

[root@yunwei ~]# awk '{i=i+1} END{print i}' /etc/passwd
30
[root@yunwei ~]# cat /etc/passwd | wc -l
30

END{}内容会在awk读取完成文件的时候执行.

END{}一般用于输出执行结果.

i=i+1 === i++

案例二:计算总和

seq 10 > num.txt计算num.txt每一行的数字的总和

[root@yunwei ~]# awk '{i=i+$1}END{print i}' num.txt
55
  • 22
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值