【基础】每天掌握一个Linux命令 - awk

news2025/6/7 7:18:03

目录

  • 【基础】每天掌握一个Linux命令 - awk
    • 一、工具概述
    • 二、安装方式
      • Ubuntu/Debian系统:
      • CentOS/RHEL系统:
      • macOS系统:
    • 三、核心功能
    • 四、基础用法
      • 基本语法
      • 常用选项
      • 内置变量
      • 基本操作示例
        • 1. 打印文件所有内容
        • 2. 打印每行的第一个字段
        • 3. 指定分隔符为冒号(:),打印每行的第三个字段
        • 4. 打印包含特定字符串的行
        • 5. 打印行数
        • 6. 打印字段数最多的行
        • 7. 计算所有数字的总和
        • 8. 打印每行的字段数
    • 五、进阶操作
      • 1. 使用条件表达式筛选数据
        • 示例数据 (students.txt):
        • 打印数学成绩大于80的学生
        • 计算并打印每个学生的平均分
      • 2. 使用循环处理数据
        • 打印每个学生的所有成绩
      • 3. 多文件处理
        • sales1.txt:
        • sales2.txt:
        • 计算每个产品的总销售额
      • 4. 格式化输出
        • 按列对齐输出学生成绩和平均分
      • 5. 内置函数应用
        • 字符串处理示例:转换为大写
        • 数学函数示例:计算平方根
    • 六、实战案例
      • 1. 面试题实战
        • 题目:统计日志文件中每个IP的访问次数,并按次数降序排列
        • 题目:提取日志中状态码为404的URL
      • 2. 生产场景实战
        • 案例1:监控服务器负载
        • 案例2:分析系统日志
        • 案例3:处理CSV文件
      • 3. 文本处理实战
        • 案例1:提取HTML标签内容
        • 案例2:批量重命名文件
    • 七、注意事项

【基础】每天掌握一个Linux命令 - awk

在Linux的世界里,当你面对海量数据需要筛选、统计时,awk就像是一把精准的手术刀,能迅速定位并处理你需要的信息。简单来说,它是一个强大的文本分析工具,让你无需编写复杂的程序,就能轻松完成数据提取与转换,特别适合处理格式化文本,如日志文件、CSV表格等。

一、工具概述

awk是一种优良的文本处理工具,Linux及Unix环境中现有的功能最强大的数据处理引擎之一。其名称得自于它的创始人 Alfred Aho、Peter Weinberger 和 Brian Kernighan 姓氏的首个字母。awk程序设计语言,包括正则表达式、循环、变量等,支持用户自定义函数和动态正则表达式等先进功能,是数据处理和报表生成的理想工具。

二、安装方式

在大多数Linux发行版中,awk通常已经预装。如果需要检查是否安装,可以使用以下命令:

awk --version

如果系统中没有安装,可以使用包管理器进行安装:

Ubuntu/Debian系统:

sudo apt-get install gawk

CentOS/RHEL系统:

sudo yum install gawk

macOS系统:

brew install gawk

三、核心功能

功能分类功能描述
文本处理逐行读取文本并按指定规则处理,可结合正则表达式进行模式匹配
数据提取根据字段分隔符分割每行文本,提取特定字段内容
格式化输出按照指定格式输出处理后的数据,支持对齐、填充等
统计分析计算总和、平均值、最大值、最小值等统计信息
条件判断根据条件表达式筛选符合条件的记录
循环处理支持for、while等循环结构,处理复杂数据
自定义函数允许用户创建自定义函数扩展功能
文件操作可以读取和处理多个输入文件,支持输出到文件

四、基础用法

基本语法

awk [选项] '模式{动作}' 文件1 文件2 ...

常用选项

选项描述
-F fs指定输入文件的字段分隔符,fs为分隔符字符串
-v var=val定义或设置变量var的值为val
-f file从文件file中读取awk脚本,而不是在命令行中直接输入
-W option指定GNU awk特定的选项,如–lint检查语法错误
–help显示帮助信息

内置变量

变量描述
$0当前处理的行的整行内容
1 − 1- 1n当前行被分割后的第1到第n个字段
NF当前行的字段数量
NR到目前为止已处理的行数
FNR当前文件已处理的行数
FS输入字段分隔符,默认是空格或制表符
OFS输出字段分隔符,默认是空格
RS输入记录分隔符,默认是换行符
ORS输出记录分隔符,默认是换行符
FILENAME当前输入文件的名称
ARGC命令行参数的数量
ARGV命令行参数数组

基本操作示例

1. 打印文件所有内容
awk '{print}' filename.txt
2. 打印每行的第一个字段
awk '{print $1}' filename.txt
3. 指定分隔符为冒号(😃,打印每行的第三个字段
awk -F: '{print $3}' /etc/passwd
4. 打印包含特定字符串的行
awk '/pattern/{print}' filename.txt
5. 打印行数
awk 'END{print NR}' filename.txt
6. 打印字段数最多的行
awk '{if(NF>max) max=NF; maxline=$0} END{print maxline}' filename.txt
7. 计算所有数字的总和
awk '{sum+=$1} END{print sum}' numbers.txt
8. 打印每行的字段数
awk '{print NF}' filename.txt

五、进阶操作

1. 使用条件表达式筛选数据

示例数据 (students.txt):
Alice 85 90 78
Bob 76 88 92
Charlie 92 89 95
David 65 70 68
打印数学成绩大于80的学生
awk '$2 > 80 {print $1, $2}' students.txt

输出结果:

Alice 85
Charlie 92
计算并打印每个学生的平均分
awk '{avg=($2+$3+$4)/3; print $1, avg}' students.txt

输出结果:

Alice 84.3333
Bob 85.3333
Charlie 92
David 67.6667

2. 使用循环处理数据

打印每个学生的所有成绩
awk '{for(i=2; i<=NF; i++) print $1, "subject", i-1, ":", $i}' students.txt

输出结果:

Alice subject 1 : 85
Alice subject 2 : 90
Alice subject 3 : 78
Bob subject 1 : 76
Bob subject 2 : 88
Bob subject 3 : 92
Charlie subject 1 : 92
Charlie subject 2 : 89
Charlie subject 3 : 95
David subject 1 : 65
David subject 2 : 70
David subject 3 : 68

3. 多文件处理

假设有两个文件:sales1.txtsales2.txt,内容如下:

sales1.txt:
ProductA 100 15
ProductB 200 20
sales2.txt:
ProductA 150 18
ProductC 300 25
计算每个产品的总销售额
awk '{total[$1] += $2 * $3} END{for(product in total) print product, total[product]}' sales1.txt sales2.txt

输出结果:

ProductA 4200
ProductB 4000
ProductC 7500

4. 格式化输出

按列对齐输出学生成绩和平均分
awk '{avg=($2+$3+$4)/3; printf "%-10s %3d %3d %3d %6.2f\n", $1, $2, $3, $4, avg}' students.txt

输出结果:

Alice      85  90  78  84.33
Bob        76  88  92  85.33
Charlie    92  89  95  92.00
David      65  70  68  67.67

5. 内置函数应用

字符串处理示例:转换为大写
awk '{print toupper($1)}' students.txt

输出结果:

ALICE
BOB
CHARLIE
DAVID
数学函数示例:计算平方根
awk '{print sqrt($2)}' numbers.txt

六、实战案例

1. 面试题实战

题目:统计日志文件中每个IP的访问次数,并按次数降序排列

示例日志 (access.log):

192.168.1.1 - - [01/Jan/2023:00:00:01 +0800] "GET /index.html HTTP/1.1" 200 1234
192.168.1.2 - - [01/Jan/2023:00:00:02 +0800] "GET /index.html HTTP/1.1" 200 1234
192.168.1.1 - - [01/Jan/2023:00:00:03 +0800] "GET /about.html HTTP/1.1" 200 1234

解决方案:

awk '{count[$1]++} END{for(ip in count) print ip, count[ip]}' access.log | sort -k2 -nr

输出结果:

192.168.1.1 2
192.168.1.2 1
题目:提取日志中状态码为404的URL

解决方案:

awk '$9 == "404" {print $7}' access.log

2. 生产场景实战

案例1:监控服务器负载

需求: 实时监控服务器的CPU使用率,当超过80%时发出警告

解决方案:

top -bn1 | grep "Cpu(s)" | awk '{print $2 + $4}' | awk '{if($1 > 80) print "CPU警告: 当前使用率为", $1, "%"}'
案例2:分析系统日志

需求: 统计/var/log/syslog中出现次数最多的5个程序

解决方案:

grep -oP '\[\K[^]]+' /var/log/syslog | awk '{count[$1]++} END{for(prog in count) print count[prog], prog}' | sort -nr | head -5
案例3:处理CSV文件

需求: 从销售数据中计算每个地区的总销售额

示例数据 (sales.csv):

Region,Product,Amount
North,ProductA,1000
South,ProductB,1500
North,ProductC,2000

解决方案:

awk -F',' 'NR>1 {total[$1]+=$3} END{for(region in total) print region, total[region]}' sales.csv

输出结果:

North 3000
South 1500

3. 文本处理实战

案例1:提取HTML标签内容

需求: 从HTML文件中提取所有链接

解决方案:

awk -v RS='</a>' '/<a / {match($0, /href="[^"]+"/); print substr($0, RSTART+6, RLENGTH-7)}' index.html
案例2:批量重命名文件

需求: 将所有.jpg文件重命名为JPG后缀

解决方案:

ls *.jpg | awk -F. '{print "mv", $0, $1 ".JPG"}' | sh

七、注意事项

  1. 字段分隔符问题:默认情况下,awk使用空格或制表符作为字段分隔符。如果数据中包含多个连续空格,可能会导致字段分割不准确。此时应使用-F选项明确指定分隔符。

  2. 变量区分大小写:awk中的变量区分大小写,例如varVar是不同的变量。

  3. 正则表达式陷阱:在awk中使用正则表达式时,需要注意元字符的转义问题。例如,要匹配点号(.),需要使用\.

  4. 性能考虑:虽然awk是处理文本的强大工具,但在处理超大型文件时,性能可能会成为问题。此时应考虑使用更高效的工具或优化awk脚本。

  5. BEGIN和END块:BEGIN块在处理输入文件之前执行,END块在处理完所有输入文件后执行。这两个块是可选的,但在需要初始化变量或输出汇总信息时非常有用。

  6. 内置函数限制:不同版本的awk可能支持不同的内置函数。在使用特定函数之前,最好先查阅对应版本的文档。

  7. 文件读取顺序:当处理多个输入文件时,awk会按命令行中指定的顺序依次处理每个文件。FNR变量会在每个文件开始时重置,而NR变量会继续递增。

  8. 字符串和数值比较:awk会自动识别变量的类型,但在进行比较时需要注意类型转换问题。例如,字符串"10"在数值比较时会被转换为数字10。

  9. 命令行参数限制:如果需要传递大量参数给awk,可能会遇到系统命令行长度限制的问题。此时应考虑将参数存储在文件中,然后使用-f选项读取。

  10. 错误处理:在编写复杂的awk脚本时,建议使用-W lint选项检查语法错误,确保脚本的正确性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2402610.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

《UE5_C++多人TPS完整教程》学习笔记37 ——《P38 变量复制(Variable Replication)》

本文为B站系列教学视频 《UE5_C多人TPS完整教程》 —— 《P38 变量复制&#xff08;Variable Replication&#xff09;》 的学习笔记&#xff0c;该系列教学视频为计算机工程师、程序员、游戏开发者、作家&#xff08;Engineer, Programmer, Game Developer, Author&#xff09…

AWS API Gateway配置日志

问题 访问API Gateway接口出现了403问题&#xff0c;具体报错如下&#xff1a; {"message":"Missing Authentication Token"}需要配置AWS API Gateway日志&#xff0c;看请求过程是什么样子的。 API Gateway 先找到API Gateway的的日志角色&#xff0c…

Towards Open World Object Detection概述(论文)

论文&#xff1a;https://arxiv.org/abs/2103.02603 代码&#xff1a;https://github.com/JosephKJ/OWOD Towards Open World Object Detection 迈向开放世界目标检测 Abstract 摘要 Humans have a natural instinct to identify unknown object instances in their environ…

轻松备份和恢复 Android 系统 | 4 种解决方案

我们通常会在 Android 手机上存储大量重要的个人数据&#xff0c;包括照片、视频、联系人、信息等等。如果您不想丢失宝贵的数据&#xff0c;可以备份 Android 数据。当您需要访问和使用这些数据时&#xff0c;可以将其恢复到 Android 设备。如果您想了解 Android 备份和恢复&a…

具备强大的数据处理和分析能力的智慧地产开源了

智慧地产视觉监控平台是一款功能强大且简单易用的实时算法视频监控系统。它的愿景是最底层打通各大芯片厂商相互间的壁垒&#xff0c;省去繁琐重复的适配流程&#xff0c;实现芯片、算法、应用的全流程组合&#xff0c;从而大大减少企业级应用约95%的开发成本。 AI是新形势下数…

【iSAQB软件架构】软件架构中构建块的视图:黑箱、灰箱和白箱及其交互机制

在软件架构描述中&#xff0c;黑箱视图&#xff08;Black-box&#xff09;、灰箱视图&#xff08;Gray-box&#xff09;和白箱视图&#xff08;White-box&#xff09; 是不同抽象层级的构建模块表示方式&#xff0c;用于满足不同受众和设计阶段的需求。以下是基于ISAQB标准的清…

如何在电脑上轻松访问 iPhone 文件

我需要将 iPhone 下载文件夹中的文件传输到 Windows 11 电脑上。我该怎么做&#xff1f;我可以在 Windows 11 上访问 iPhone 下载吗&#xff1f; 由于 iOS 和 Windows 系统之间的差异&#xff0c;在 PC 上访问 iPhone 文件似乎颇具挑战性。然而&#xff0c;只要使用正确的工具…

C语言字符数组输入输出方法大全(附带实例)

在 C语言中&#xff0c;字符数组是一种特殊的数组&#xff0c;用于存储和处理字符串。理解字符数组的输入和输出操作对于初学者来说至关重要&#xff0c;因为这是处理文本数据的基础。 字符数组的定义与初始化 在讨论输入输出之前&#xff0c;我们先来回顾一下字符数组的定义…

短视频矩阵SaaS系统:开源部署与核心功能架构指南

一、系统架构概述 短视频矩阵系统是基于SaaS&#xff08;软件即服务&#xff09;模式的多平台内容管理解决方案&#xff0c;通过开源技术实现账号聚合、智能创作、跨平台分发及数据闭环。系统采用微服务架构&#xff0c;支持高并发场景下的弹性扩展。 二、核心功能模块开发逻辑…

oss:上传图片到阿里云403 Forbidden

访问图片出现403Forbidden问题&#xff0c;我们可以直接登录oss账号&#xff0c;查看对应权限是否开通&#xff0c;是否存在跨域问题

4. 数据类型

4.1 数据类型分类 分类 数据类型 说明 数值类型 BIT(M) 位类型。M指定位数&#xff0c;默认值1&#xff0c;范围1 - 64 TINYINT [UNSIGNED] 带符号的范围 -128 ~ 127&#xff0c;无符号范围0 ~ 255&#xff0c;默认有符号 BOOL 使用0和1表示真和假 SMALLINT [UNSIGNED] 带符号是…

MySQL基础(二)SQL语言、客户端工具

目录 三、SQL语言 3.1 概念 3.2 基本操作 四、客户端工具 三、SQL语言 3.1 概念 SQL&#xff08;Structured Query Language&#xff09;结构化查询语言。SQL用于对存储数据&#xff0c;更新&#xff0c;查询和管理关系型数据库的程序设计语言。 通常执行对数据库的增删改…

CppCon 2015 学习:C++ in the audio industry

实时编程&#xff08;real-time programming&#xff09;&#xff1a;音频处理对延迟极度敏感&#xff0c;要求代码必须非常高效且稳定。无锁线程同步&#xff08;lock-free thread synchronization&#xff09;&#xff1a;避免阻塞&#xff0c;提高性能&#xff0c;尤其是在多…

C++算法-动态规划2

第 4 题 字符串分割 (Word Break) 难度: Medium备注&#xff1a;出自 leetcode题目描述 Given a string s and a dictionary of words dict, determine if s can be segmented into a space-separated sequence of one or more dictionary words. For example, given s "l…

软信天成:数据驱动型背后的人工智能,基于机器学习的数据管理

在数字化转型浪潮中&#xff0c;当代企业如同逆水行舟&#xff0c;不进则退。无数企业希望通过数字化转型捕获全新的市场机遇&#xff0c;改善财政状况&#xff0c;在未来市场竞争中占据一席之地。要想获得成功的数字化转型&#xff0c;关键因素在于具备可靠、及时的数据用以支…

MySQL提升

事务 事务&#xff1a;在多个操作合在一起视为一个整体。要么就不做、要么就做完。 事务应该满足ACID A : 原子性。不可分割。C : 一致性。追求的目标&#xff0c;在开始到结束没有发生预定外的情况。I : 隔离性。不同的事务是独立的。D : 持久性。系统崩溃&#xff0c;数据依然…

go语言的锁

本篇文章主要讲锁&#xff0c;主要会涉及go的sync.Mutex和sync.RWMutex。 一.锁的概念和发展 1.1 锁的概念 所谓的加锁和解锁其实就是指一个数据是否被占用了&#xff0c;通过Mutex内的一个状态来表示。 例如&#xff0c;取 0 表示未加锁&#xff0c;1 表示已加锁&#xff…

VUE解决页面请求接口大规模并发的问题(请求队列)

方案1&#xff1a; 请求队列 // RequestQueue.js export default class RequestQueue {constructor(maxConcurrent) {this.maxConcurrent maxConcurrent; // 最大并发请求数this.currentConcurrent 0; // 当前并发请求数this.queue []; // 请求队列this.requestId 0; // …

IDEA安装迁移IDEA配置数据位置

需求 因为C盘有清空风险&#xff0c;需要把IDEA&#xff08;2025&#xff09;安装位置以及配置数据都挪到D盘。 安装 到官网下载安装包 安装&#xff0c;这里可以改下安装位置 这几个选项随意&#xff0c;然后一直下一步就好 完成后重启或不重启都随意 迁移数据 初次安…

Blazor-表单提交的艺术:如何优雅地实现 (下)

在上一章节中我们使用HTML的方式介绍了如何在Blazor框架下进行表单的提交&#xff0c;而在Blazor框架中也为我们内置了<EditForm>组件来代替原始的HTML,<form>&#xff0c;下面我们将对<EditForm>的用法进行讲解&#xff0c;并将两种表单方式进行对比&#x…