Linux awk命令基本如何使用及说明

Linux awk命令基本使用 awk命令是一种处理文本的语言,是一个强大的文本分析工具,比较适用于文本的格式化。awk命令结构: awk BEGIN{com

Linux awk命令基本使用

awk命令是一种处理文本的语言,是一个强大的文本分析工具,比较适用于文本的格式化。awk命令结构:

awk 'BEGIN{commands} pattern{command} END{command}'

awk工作流程可以分为三个部分:

  • 读取输入文件之前执行的代码段(由BEGIN关键字标识)
  • 主循环执行输入文件的代码段
  • 读取输入文件之后的代码段(由END关键字 标识)

基本用法

用法一:

awk '{[pattern] action}'  {filename}	
#行匹配语句 awk ' '这里只能用单引号。

实例:

1、创建一个测试文本文件如下;

2、输出test1.txt第一列、第三列和第四列,并且按空格分隔;

awk '{print $1,$3,$4}' test1.txt

输出结果

格式化输出,列对齐;

awk '{printf "%-5s %-5s\n",$3,$4}' test1.txt
#这里%-5s的数字可以更改用来调整列之间的间隔

用法二:

awk -F #这里的-F相当于内置变量FS,指定分割字符
awk -F, '{print $1,$2,$3}' test1.txt
#将文本中的逗号替换成空格,进行分割
awk 'BEGIN{FS=","}{print $1,$2,$3}' test1.txt
#相当于内置变量FS
awk -F '[ ,]' '{print $1,$2,$3}' test1.txt
#使用多个分隔符,先使用空格分割,然后对分割结果在使用都好分割

用法三:

awk -v #设置变量
awk -va=1 '{print $1,$1+a}' test1.txt

输出结果

awk -vb=s '{print $1,$1b}' test1.txt

用法四:

awk -f {awk脚本} {filename}
awk -f cal.awk test1.txt

使用运算符

用法五:

awk '$1>2 {print $0}' test1.txt
#输出第一列大于2的行
awk '$1==3 {print $0}' test1.txt
#输出第一列等于3的行
awk '$1>2 && $2=="carl"{print $0}' test1.txt
#输出第一列大于2,第二列等于carl的行

使用内置变量:

内置变量有如下多种:

awk '{print NR,FNR,$3}' test1.txt
#输出顺序号NR,匹配文本行号;

指定输出分割符OFS:

awk '{print $1,$2,$3,$4}' OFS="," test1.txt

使用正则,进行字符串匹配

awk '$3~/a/ {print $0}' test1.txt
#输出第三列包含a的所有行,~表示模式开始,//中是模式
awk '/a/' test1.txt
#输出包含a的行

忽略匹配字符的大小写:

awk 'BEGIN{IGNORECASE=1} /a/' test1.txt
#即可以匹配包含A 或 a的行

模式取反:

awk '$3!~/a/ {print $0}' test1.txt
#输出第三列不包含a的所有行,~表示模式开始,//中是模式
awk '!/a/' test1.txt
#输出不包含a的行

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持好代码网。

标签: Linux awk命令