awk入门 —— 强大的文本分析工具

系统 Linux
awk 是用于 Unix 和类 Unix 系统的强大文本解析工具,但是由于它有可编程函数,因此你可以用它来执行常规解析任务,因此它也被视为一种编程语言。你可能不会使用 awk 开发下一个 GUI 应用,并且它可能不会代替你的默认脚本语言,但是它是用于特定任务的强大程序。

[[281490]]

让我们开始使用它。

awk 是用于 Unix 和类 Unix 系统的强大文本解析工具,但是由于它有可编程函数,因此你可以用它来执行常规解析任务,因此它也被视为一种编程语言。你可能不会使用 awk 开发下一个 GUI 应用,并且它可能不会代替你的默认脚本语言,但是它是用于特定任务的强大程序。

这些任务或许是惊人的多样化。了解 awk 可以解决你的哪些问题的最好方法是学习 awk。你会惊讶于 awk 如何帮助你完成更多工作,却花费更少的精力。

awk 的基本语法是:

  1. awk [options] 'pattern {action}' file

首先,创建此示例文件并将其保存为 colours.txt

  1. name       color  amount
  2. apple      red    4
  3. banana     yellow 6
  4. strawberry red    3
  5. grape      purple 10
  6. apple      green  8
  7. plum       purple 2
  8. kiwi       brown  4
  9. potato     brown  9
  10. pineapple  yellow 5

数据被一个或多个空格分隔为列。以某种方式组织要分析的数据是很常见的。它不一定总是由空格分隔的列,甚至可以不是逗号或分号,但尤其是在日志文件或数据转储中,通常有一个可预测的格式。你可以使用数据格式来帮助 awk 提取和处理你关注的数据。

打印列

awk 中,print 函数显示你指定的内容。你可以使用许多预定义的变量,但是最常见的是文本文件中以整数命名的列。试试看:

  1. $ awk '{print $2;}' colours.txt
  2. color
  3. red
  4. yellow
  5. red
  6. purple
  7. green
  8. purple
  9. brown
  10. brown
  11. yellow

在这里,awk 显示第二列,用 $2 表示。这是相对直观的,因此你可能会猜测 print $1 显示第一列,而 print $3 显示第三列,依此类推。

要显示全部列,请使用 $0

美元符号($)后的数字是表达式,因此 $2$(1+1) 是同一意思。

有条件地选择列

你使用的示例文件非常结构化。它有一行充当标题,并且各列直接相互关联。通过定义条件,你可以限定 awk 在找到此数据时返回的内容。例如,要查看第二列中与 yellow 匹配的项并打印第一列的内容:

  1. awk '$2=="yellow"{print $1}' file1.txt
  2. banana
  3. pineapple

正则表达式也可以工作。此表达式近似匹配 $2 中以 p 开头跟上任意数量(一个或多个)字符后继续跟上 p 的值:

  1. $ awk '$2 ~ /p.+p/ {print $0}' colours.txt
  2. grape   purple  10
  3. plum    purple  2

数字能被 awk 自然解释。例如,要打印第三列包含大于 5 的整数的行:

  1. awk '$3>5 {print $1, $2}' colours.txt
  2. name    color
  3. banana  yellow
  4. grape   purple
  5. apple   green
  6. potato  brown

字段分隔符

默认情况下,awk 使用空格作为字段分隔符。但是,并非所有文本文件都使用空格来定义字段。例如,用以下内容创建一个名为 colours.csv 的文件:

  1. name,color,amount
  2. apple,red,4
  3. banana,yellow,6
  4. strawberry,red,3
  5. grape,purple,10
  6. apple,green,8
  7. plum,purple,2
  8. kiwi,brown,4
  9. potato,brown,9
  10. pineapple,yellow,5

只要你指定将哪个字符用作命令中的字段分隔符,awk 就能以完全相同的方式处理数据。使用 --field-separator(或简称为 -F)选项来定义分隔符:

  1. $ awk -F"," '$2=="yellow" {print $1}' file1.csv
  2. banana
  3. pineapple

保存输出

使用输出重定向,你可以将结果写入文件。例如:

  1. $ awk -F, '$3>5 {print $1, $2} colours.csv > output.txt

这将创建一个包含 awk 查询内容的文件。

你还可以将文件拆分为按列数据分组的多个文件。例如,如果要根据每行显示的颜色将 colours.txt 拆分为多个文件,你可以在 awk 中包含重定向语句来重定向每条查询

  1. $ awk '{print > $2".txt"}' colours.txt

这将生成名为 yellow.txtred.txt 等文件。 

责任编辑:庞桂玉 来源: Linux中国
相关推荐

2021-03-06 07:00:00

awk文本分析工具Linux

2019-03-21 14:30:15

Linux文本分析命令

2016-12-23 10:56:34

linuxshellawk

2020-07-07 10:50:19

Python丄则表达文本

2024-09-23 09:20:00

Python文本分析

2010-01-05 16:55:44

JSON 文本

2017-04-27 08:54:54

Python文本分析网络

2020-08-26 19:15:56

Python工具

2022-10-09 08:00:00

机器学习文本分类算法

2023-11-28 15:18:24

Python

2010-08-03 16:17:17

NFS协议

2010-09-06 14:14:32

ppp-on

2023-10-20 16:25:30

Python

2021-07-08 06:47:19

JVM监控工具

2013-03-07 09:30:51

云成本分析工具云服务亚马逊云服务

2018-01-24 09:27:30

文本分类工具fastText

2021-11-01 05:53:08

Doldrums逆向工程分析工具安全工具

2021-03-29 23:05:36

程序员工具静态分析

2022-08-18 11:36:28

网络嗅探工具网络安全

2020-12-07 14:46:07

程序员代码分析工具
点赞
收藏

51CTO技术栈公众号