我是awk编程的新手,对NR变量的使用有点困惑.
我的代码是…
awk 'BEGIN {k=NR;}{printf("%s %s %s %s\n",$k,$(k+1),$(k+2),$(k+3))}' auth_data
$cat auth_data
6262 6530 6661 3162 6364 6264 6561 3430 3033 3332 6536 3139 6230 6261 61
30 3637 0A00 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000
0000 0000 0000
输出:
6262 6530 6661 3162 6364 6264 6561 3430 3033 3332 6536 3139 6230 6261 6130
3637 0A00 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000
0000 0000 6262 6530 6661
但是我想要的是输出应采用以下格式:
6262 6530 6661 3162 6364 6264 6561 3430
3033 3332 6536 3139 6230 6261 6130 3637
0A00 0000 0000 0000 0000 0000 0000 0000
0000 0000 0000 0000 0000 0000 0000 0000
解决方法:
我猜您正在寻找的是NF,而不是NR.
来自联机帮助页:
NR The total number of input records seen so far.
NR是实际的行号,但是在此问题中,您想对字段idx而不是行做一些技巧.
另外,我认为您的输入数据应该在文件“ auth_data”中的一行中,对吗?
如果是这样,您可以尝试
awk '{for(i=1;i<=NF;i++)if(i%8==0)print $i;else printf $i" "}' auth_data
检查以下测试:
kent$ echo "6262 6530 6661 3162 6364 6264 6561 3430 3033 3332 6536 3139 6230 6261 6130 3637 0A00 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000"|\
awk '{for(i=1;i<=NF;i++)if(i%8==0)print $i;else printf $i" "}'
6262 6530 6661 3162 6364 6264 6561 3430
3033 3332 6536 3139 6230 6261 6130 3637
0A00 0000 0000 0000 0000 0000 0000 0000
0000 0000 0000 0000 0000 0000 0000 0000
回到问题,如果您只想进行格式化,那么xargs就足够了.见下文:
kent$ echo "6262 6530 6661 3162 6364 6264 6561 3430 3033\
3332 6536 3139 6230 6261\
6130 3637 0A00 0000 0000 \
0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000"|xargs -n8
输出:
6262 6530 6661 3162 6364 6264 6561 3430
3033 3332 6536 3139 6230 6261 6130 3637
0A00 0000 0000 0000 0000 0000 0000 0000
0000 0000 0000 0000 0000 0000 0000 0000
您可以为yourFile | xargs -n8或xargs -n8 -a yourfile设置目录
标签:bash,shell,awk,linux
来源: https://codeday.me/bug/20191202/2086349.html