awk命令语法:
awk [选项] ‘条件{动作} 条件{动作} ... ...’ 文件名
花括号内可以包含多个动作,多个动作之间使用分号分隔。
如果没有指定条件则默认匹配所有数据
如果没有指定动作则默认为print打印
1.内置变量:
|
变量名
|
描述
|
|
FILENAME
|
当前输入文档的名称
|
|
FNR
|
当前输入文档的当前行号,尤其当有多个输入文档时有用
|
|
NR
|
输入数据流的当前行号
|
|
$0
|
当前行的全部数据内容
|
|
$n
|
当前行的第N个字段的内容
|
|
NF
|
当前记录的字段个数
|
|
FS
|
字段分隔符,默认为空格或者Tab
|
|
RS
|
输入记录分隔符,默认为换行符\n
|
|
OFS
|
输出字段分隔符,默认为换行符\n
|
|
ORS
|
输出记录分隔符,默认为换行符\n
|
-
NR:可以理解为Number of records。当处理多个文件时,NR会累加,处理多个文件时NR并不会从1开始。对应的行
-
FNR:针对每个文件,FNR会从1开始计数。
-
NF:表示目前的记录被分割的字段数目。number of fields。对应的列。通过$NF可以获取最后一个列字段的内容。
-
FS 输入字段分隔符,默认是空格
示例:
CodingAnts@ubuntu:~/awk$ cat class1
zhaoyun 85 87
guanyu 87 88
liubei 90 86
CodingAnts@ubuntu:~/awk$ cat class2
caocao 92 87 90
guojia 99 96 92
CodingAnts@ubuntu:~/awk$ awk '{print NR,$0}' class1 class2
1 zh

本文介绍了awk中的两个重要函数sub()和substr()。sub()用于替换字符串中第一个匹配的部分,而substr()则用于从字符串中截取指定部分。NR表示记录总数,FNR针对每个文件单独计数,NF表示当前记录的字段数量。FS定义输入字段的分隔符,$NF则获取最后一个字段。通过对这两个函数的理解,可以更高效地进行文本处理。
2350

被折叠的 条评论
为什么被折叠?



