有两个文本A.txt和B.txt,内容如下:
A.txt:
line1 123
line2 234
line3 345
line4 456
B.txt:
234
456
怎么样才能得到文本C.txt, 将文本A.txt中第2列数据含有文本B.txt的行标出,得到结果如(比如在第1列末尾加[*]):
C.txt:
line1 123
line2[*] 234
line3 345
line4[*] 456
awk 'NR==FNR{a[$0];next}$2 in a{$1=$1"[*]"}1' B.txt A.txt
awk 'NR==FNR{a[$0];next} {if ($2 in a){$1=$1"[*]";print $0}}' B.txt A.txt
awk 'NR==FNR{a[$0]=$0;next}{for(i in a){if(a[i]==$2)t=$1"[*]"}printf("%-10s%s\n",t?t:$1,$2);t=""}' B.txt A.txt
NR,表示awk开始执行程序后所读取的数据行数.
FNR,与NR功用类似,不同的是awk每打开一个新文件,FNR便从0重新累计.
下面看两个例子:
1,对于单个文件NR 和FNR 的 输出结果一样的 :
# awk '{print NR,$0}' file1
1 a b c d
2 a b d c
3 a c b d
#awk '{print FNR,$0}' file1
1 a b c d
2 a b d c
3 a c b d
2,但是对于多个文件 :
# awk '{print NR,$0}' file1 file2
1 a b c d
2 a b d c
3 a c b d
4 aa bb cc dd
5 aa bb dd cc
6 aa cc bb dd
# awk '{print FNR,$0}' file1 file2
1 a b c d
2 a b d c
3 a c b d
1 aa bb cc dd
2 aa bb dd cc
3 aa cc bb dd
在看一个例子关于NR和FNR的典型应用:
现在有两个文件格式如下:
#cat account
张三|000001
李四|000002
#cat cdr
000001|10
000001|20
000002|30
000002|15
想要得到的结果是将用户名,帐号和金额在同一行打印出来,如下:
张三|000001|10
张三|000001|20
李四|000002|30
李四|000002|15
执行如下代码
#awk -F \| 'NR==FNR{a[$2]=$0;next}{print a[$1]"|"$2}' account cdr
注释:
由NR=FNR为真时,判断当前读入的是第一个文件account,然后使用{a[$2]=$0;next}循环将account文件的每行记录都存入数组a,并使用$2第2个字段作为下标引用.
由NR=FNR为假时,判断当前读入了第二个文件cdr,然后跳过{a[$2]=$0;next},对第二个文件cdr的每一行都无条件执行{print a[$1]"|"$2},此时变量$1为第二个文件的第一个字段,与读入第一个文件时,采用第一个文件第二个字段$2为数组下标相同.因此可以在此使用a[$1]引用数组。
相关推荐
LINUX SHELL命令练习 题
bash shell 习题集 word文字版 方便大家对shell的学习
linux操作题及答案shell练习题.pdf
shell练习题1.doc
shell编程题目练习,练习基本的shell编程,学习脚本语言,提高效率
shell练习题,很全,不错,还可以,努力吧,学习ing......
linux中shell练习-习题5
LINUXSHELL命令练习题[参考].pdf
shell脚本
Linux运维-3.Shell编程-11shell基础-119四则运算练习题1.avi
。。。
。。。
。。。
。。。
16shell脚本进阶_练习答案。 1. 判断/var/目录下所有文件的类型 ...3. /etc/rc.d/rc3.d目录下分别有多个以K开头和以S开头的文件;...练习题地址: https://thson.blog.csdn.net/article/details/92082781
LinuxShell自动化运维-课后习题答案.docx
Linux实习三报告 VI编辑器及shell命令Linux实习三报告 VI编辑器及shell命令
HDFSShell命令综合练习.pdf 学习资料 复习资料 教学资源