欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 房产 > 建筑 > linux-awk分析指令

linux-awk分析指令

2025/3/10 15:31:15 来源:https://blog.csdn.net/luoqjcandy/article/details/139665681  浏览:    关键词:linux-awk分析指令

目录

基本用法:

条件语句:

内置变量:

自定义分隔符:

数学运算:

使用多个文件:

生成“完整使用报告”的示例:

8. 模式匹配

9. BEGIN和END模式

10. 数组和关联数组

11. 脚本方式使用

12. 逐行处理

13. 控制语句


awk 是一个强大的文本处理工具,用于在文本文件中执行模式扫描和文本/数据提取。下面我将为您展示一些 awk 的基本用法和示例,以及如何使用它来生成一个“完整使用报告”。但请注意,由于“完整使用报告”是一个相对模糊的概念,我将为您提供一系列常见的 awk 用法示例。

  1. 基本用法:

    • 打印文件中的所有内容:
    awk '{print}' filename
    • 打印文件的第一列:
     
    awk '{print $1}' filename
    • 打印文件的第一行:
     
    awk 'NR==1 {print}' filename
    • 打印文件的最后一行:
     
    awk 'END {print}' filename
  2. 条件语句:

    • 打印文件中大于10的数字所在的行:
     
    awk '$1>10' filename
    • 如果第一列大于10,则打印第一列和第二列:
     
    awk '$1>10 {print $1, $2}' filename
  3. 内置变量:

    • 打印文件的行数:
     
    awk 'END {print NR}' filename
    • 打印每行的字段数量:
     
    awk '{print NF}' filename
  4. 自定义分隔符:

    • 使用冒号 : 作为字段分隔符,并打印第一列:
     
    awk -F: '{print $1}' filename
  5. 数学运算:

    • 计算第一列和第二列的和,并打印结果:
     
    awk '{sum=$1+$2; print sum}' filename
  6. 使用多个文件:

    • 假设我们有两个文件 file1.txt 和 file2.txt,我们想要打印两个文件中都有的行(基于整行内容):
     
    awk 'FNR==NR{a[$0];next} $0 in a' file1.txt file2.txt

    生成“完整使用报告”的示例:

假设我们有一个名为 sales.txt 的文件,内容如下:

 
ProductID,ProductName,QuantitySold,Price
1,Apple,10,2.5
2,Banana,20,1.2
3,Cherry,5,3.8

我们可以使用 awk 来生成一个“销售报告”,例如:

 
awk -F, 'NR>1 {print "Product:", $2, "sold", $3, "units at", $4, "per unit, total:", $3*$4}' sales.txt

输出:

Product: Apple sold 10 units at 2.5 per unit, total: 25
Product: Banana sold 20 units at 1.2 per unit, total: 24
Product: Cherry sold 5 units at 3.8 per unit, total: 19


8. 模式匹配

  • 正则表达式awk 支持强大的正则表达式和模式匹配功能。

awk '/pattern/{print}' data.txt # 打印匹配pattern的行

9. BEGIN和END模式

  • BEGIN:在处理任何输入文件之前执行。

  • END:在所有输入文件都被处理完后执行。

 
awk -F: 'BEGIN {print "Username\tShell"} {print $1"\t"$7} END {print "blue\t/bin/nosh"}' /etc/passwd

10. 数组和关联数组

  • 定义数组:使用 数组名[下标] = 元素值 的格式定义数组。
  • 遍历数组:使用 for(变量 in 数组名) 遍历数组。

11. 脚本方式使用

  • 将所有的 awk 命令插入一个文件,并使 awk 程序可执行,然后通过键入脚本名称来调用。

  • 使用 -f 选项加载 awk 脚本文件。

 
awk -f awk-script-file input-file(s)

12. 逐行处理

  • awk 最适合逐行处理文本文件,按行分割的文本数据是 awk 的主要应用场景。

13. 控制语句

  • awk 支持分支结构(单分支、双分支、多分支)、循环结构(while、do-while、for)以及其他控制语句(如中断、退出等)。

这只是一个简单的示例来展示如何使用 awk 来处理文本文件和生成报告。您可以根据自己的需求进一步定制 awk 脚本。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com