查看原文
其他

Linux系统文本三剑客:AWK命令

李逸皓 运维book思议 2023-10-21

放个链接,万一有人关注呢

优质文章推荐

↓ ↓ ↓ ↓ ↓

Linux系统文本三剑客:Sed命令

Linux系统日志自动化管理脚本

Python脚本实现应用自动化部署

Linux系统数据安全备份脚本

Python脚本实现数据库自动化备份

Linux系统应用代码自动发布更新脚本

AWK是一种强大的文本处理工具,它在Unix和Linux系统中广泛使用。它可以帮助我们对文本数据进行提取、转换和分析,使得处理大规模文本文件变得高效和便捷。

什么是AWK命令?

AWK是一种文本处理语言,它通过定义模式和操作来处理文本数据。它的名称来源于其三位创始人(Alfred Aho,Peter Weinberger和Brian Kernighan)的姓氏的首字母。

AWK的基本用法是将输入文本分割为记录和字段,然后根据指定的模式匹配进行相应的操作。它使用行为模式对数据进行过滤、转换和打印。

基本用法

下面是AWK命令的基本语法:

awk 'pattern { action }' filename

其中,pattern是用来匹配文本的条件,action是在满足模式的情况下执行的操作。filename是输入的文件名。
现在我们来看一些实际的例子来理解AWK命令的使用方式。
示例1: 提取文本中的特定列 
假设我们有一个包含学生信息的文本文件,每行包含姓名、年龄和分数,字段之间用逗号分隔。我们想要提取分数大于80的学生的姓名和年龄。
假设我们的文件名为students.txt,内容如下:
John,18,75Lisa,20,90Tom,19,85Alice,18,92

我们可以使用AWK命令来实现这个需求:

awk -F ',' '$3 > 80 { print $1, $2 }' students.txt
这里,-F ','指定字段分隔符为逗号,$3 > 80表示第三个字段(分数)大于80的条件,print $1, $2用于打印满足条件的第一个和第二个字段(姓名和年龄)。
执行以上命令后,输出将为:
Lisa 20Tom 19Alice 18

示例2: 根据条件筛选和计算 
假设我们有一个包含员工信息的文本文件,每行包含员工姓名、部门和工资,字段之间用制表符分隔。我们想要筛选出部门为销售部门的员工,并计算他们的平均工资。
假设我们的文件名为employees.txt,内容如下:
John Sales 3000Lisa IT 4000Tom Sales 2500Alice   Finance  3500

我们可以使用AWK命令来实现这个需求:

awk -F '\t' '$2 == "Sales" { sum += $3; count++ } END { avg = sum / count; print "销售部门平均工资: " avg }' employees.txt
这里,-F '\t'指定字段分隔符为制表符,$2 == "Sales"表示第二个字段(部门)等于"Sales"的条件,{ sum += $3; count++ }用于累加工资和计数,END { avg = sum / count; print "销售部门平均工资: " avg }在处理完所有行后计算平均工资并打印结果。
执行以上命令后,输出将为:
销售部门平均工资: 2750

示例3: 替换和修改文本 
假设我们有一个文本文件data.txt,其中包含一些单词,我们想要将其中的"apple"替换为"orange",并将每个单词转换为大写。
我们可以使用AWK命令来实现这个需求:
awk '{ gsub("apple", "orange"); print toupper($0) }' data.txt
这里,gsub("apple", "orange")用于替换文本中的"apple"为"orange",toupper($0)将每个行转换为大写。
执行以上命令后,输出将为:
THIS IS AN ORANGE.THERE ARE ORANGES IN THE BASKET.


AWK是一种强大而灵活的文本处理工具,可以帮助我们对大规模文本数据进行提取、转换和分析。本文详细介绍了AWK命令的基本使用方式,并提供了多个实际示例来帮助读者理解和掌握这个强大的文本处理工具。通过灵活运用AWK命令,可以高效地处理文本数据,并在实际工作中获得更好的效果。

结束!如有不足之处,欢迎指正!

来不及解释了,快上车!(加我微信拉你进群,需要学习资料的V我)

欢迎新的小伙伴加入!在这里,我们鼓励大家积极参与群内讨论和交流,分享自己的见解和经验,一起学习和成长。同时,也欢迎大家提出问题和建议,让我们不断改进和完善这个平台。



您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存