awk1.0 — awk基础

本文介绍了 Linux 下文本处理工具 awk 的基本用法及应用场景,包括简单的文本输出、格式化输出特定列数据等,并详细解析了 awk 的工作原理及内置变量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

简介

grep,sed,awk被称为Linux文本处理的三剑客,各有特点
grep:适合文本的匹配和查找
sed:编辑匹配到的文本
awk:对文本进行格式化输出

awk简介

awk的基本语法是

awk [options] 'Pattern {Actions}' file1,file2...

Actions指的是工作,awk擅长文本输出,最常用的动作是print和printf

场景一:简单输出文本

$ touch awk.cc
$ echo "ddd" > awk.cc
$ awk '{print}' awk.cc
ddd

场景二:格式的输出某一列数据

image

上图中,首先将df的结果通过管道传给了awk,awk输出了第五列的数据,$5表示第五个。

awk工作原理

awk会逐行获取数据,然后对每一行进行处理,将一行中的数据按照“分隔符”分割成多个单次,并依次以1,1,2,3使awk3…等变量标记这些单词。用户可以指定分隔符,如果不指定的话,默认使用空格作为单词之间的分隔符。awk内置变量,0表示整行,NF()使NF表示一行中的最后一个变量(单词)。还可以使用(NF-1)表示倒数第一个变量。

其他输出形式

记住一点,awk中的单词都是以变量的形式存在

  1. 输出多列,变量以逗号隔开
# df | awk '{print $1,$NF}'
  1. 输出自定义变量
# df | awk '{print $1,$NF,"string"}'

需要注意的是,将$标识的变量和我们传入的变量分清楚就好了

awk的模式

再次重申awk的语法

awk [options] 'Pattern {Actions}' file1,file2...

这里我们再来说awk的模式,awk有很多模式,先说两个特殊的模式,BEGIN和END
BEGIN标识,在处理awk的操作之前,先要执行的操作,END标识,在执行完毕之后,再要执行的操作
image

BEGIN模式处理的一个优点就是,在格式化显示文本之前,给每一列做一个标识,BEGIN就是执行awk之前先要进行的操作。

注意:多个操作强调内容一定要在单引号内(”),要有花括号分割({})

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值