17_Shell好用工具:awk

17_Shell好用工具:awk

grep:查找

sed:编辑

cut:切割

awk:切割 + 可以通过定义变量、流程控制进行深度分析加工

一、awk内置变量

内置变量列出了几个常用的

内置变量 含义
FILENAME 文件名
NF Number Of Fields,单行总列数
NR Number Of Records,单行行号
$n 0 整条记录 1 第一列 $2 第二列
$NF 最后一列

二、awk基本使用场景举例

awk基本语法:

awk [options] 'pattern{action}' filename

2.1、默认分隔符

shell 复制代码
#默认分割符是"空格"
echo "123 456 789" | awk '{print $1"&&"$2"&&"$3}'

2.1、自定义分隔符

shell 复制代码
#使用 ":" 分隔字符串,并打印1-6列
awk -F ':' '{print $1 $2 $3 $4 $5 $6}' awk_bak.txt

2.2、内置变量

shell 复制代码
#打印文件中文件名、行号、列数
#方式1:
awk '{print "文件名:"FILENAME " 行号:"NR" 列数:"NF" 内容:"$0}' awk.txt

#方2:(推荐)
awk '{printf("文件名:%s 行号:%s 列数:%s 内容:%s\n", FILENAME, NR, NF, $0)}' awk.txt

2.3、指定行号

shell 复制代码
#打印行号等于5的行的所有内容
awk 'NR==5{print $0}' awk.txt

2.4、正则表达式

shell 复制代码
#打印包含Holen的行的所有内容
awk '/Holen/{print $0}' awk.txt

#打印以"-"开头的行
ll | awk '/^-/'

#打印以".txt"结尾的行
ll | awk '/$*.txt/'

2.5、特殊列

shell 复制代码
#打印第一列和最后一列
awk '{print "第一列:"$1 " ,最后一列:" $NF}' awk.txt

#打印倒数第二列
awk '{print "第一列:"$1 ", 最后一列:" $NF ", 倒数第二列:" $(NF-1)}' awk.txt

2.6、指定范围行、指定列

shell 复制代码
#打印第1-3行全部内容
awk '{if(NR>=1&&NR<=3){print $0}}' awk.txt

#打印第1-3行第一列内容
awk '{if(NR>=1&&NR<=3){print $1}}' awk.txt

2.7、多分割符

shell 复制代码
#分割 1:2=3?4!5>6 并打印
awk -F '[:=?!>]' '{print $1 "&&" $2 "&&" $3 "&&" $4 "&&" $5}' awk_bak.txt

2.8、添加开始和结束

shell 复制代码
#在打印Hello world之前添加start,之后添加end
echo "Hello world." | awk 'BEGIN{print "start"}{print $0}END{print "end"}'

2.9、变量定义和循环

shell 复制代码
#手动拼接分割后的字符串   列数较少推荐
echo "123 456 789" | awk '{print $1$2$3}'

#循环凭借分割后的字符串   列数较多推荐
echo "123 456 789" | awk -v str="" '{for(n=1;n<=NF;n++){ str=str$n }} END{print str}'

3.12、运算

shell 复制代码
#awk计算 $n 和 变量的运算
echo "2.1" | awk -v i=1 '{ print $0+1}'

3.13、截取IP

shell 复制代码
#截取IP
ifconfig | awk '/192.168/{print $2}'
相关推荐
物联网老王4 小时前
Ubuntu Linux Cursor 安装与使用一
linux·运维·ubuntu
一位摩羯座DBA6 小时前
Redhat&Centos挂载镜像
linux·运维·centos
学习3人组6 小时前
CentOS配置网络
linux·网络·centos
weixin_307779137 小时前
Hive集群之间迁移的Linux Shell脚本
大数据·linux·hive·bash·迁移学习
漫步企鹅7 小时前
【蓝牙】Linux Qt4查看已经配对的蓝牙信息
linux·qt·蓝牙·配对
cui_win7 小时前
【网络】Linux 内核优化实战 - net.core.flow_limit_table_len
linux·运维·网络
梦在深巷、7 小时前
MySQL/MariaDB数据库主从复制之基于二进制日志的方式
linux·数据库·mysql·mariadb
冰橙子id8 小时前
linux系统安全
linux·安全·系统安全
stark张宇8 小时前
VMware 虚拟机装 Linux Centos 7.9 保姆级教程(附资源包)
linux·后端
Johny_Zhao8 小时前
Ubuntu系统安装部署Pandawiki智能知识库
linux·mysql·网络安全·信息安全·云计算·shell·yum源·系统运维·itsm·pandawiki