[英]AWK - using element on next record GETLINE?
我在基本数据上遇到了一些问题:
DP;DG
67;
;10
;14
;14
;18
;18
;22
;65
68;
;0
;9
;25
;25
70;
我想对这种输出进行转换:
DP;DG
67;
;10
;14
;14
;18
;18
;22
;65;x
68;
;0
;9
;25
;25;x
70;
如果下一行$ 1存在或$ 2为空,则出现“ x”值。 据我了解,我必须使用getline,但我没有办法! 我尝试了以下代码:
#!/bin/bash
file2=tmp.csv
file3=fin.csv
awk 'BEGIN {FS=OFS=";"}
{
print $0;
getline;
if($2="") {print $0";x"}
else {print $0}
}' $file2 > $file3
看起来很容易。 我没有提到结果,这与我的期望完全不同。
有一些线索吗? getline是否有必要解决这个问题?
好的,我继续测试一些代码:
#!/bin/bash
file2=tmp.csv
file3=fin.csv
awk 'BEGIN {FS=OFS=";"}
{
getline var
if (var ~ /.*;$/) {
print $0";x";
print var;
}
else {
print $0;
print var;
}
}' $file2 > $file3
更好,但是仍然没有标记所有行...我不知道为什么...
尝试一下:
awk -F';' 'NR==FNR{if($1>0||!$2)a[NR-1];next}FNR in a{$0=$0";x"}7' file file
要么
awk -F';' 'NR==FNR{if($1~/\S/||$2).....
另一种通行证版本
$ awk -F\; 'NR>1 {printf "%s\n", (f && $2<0?"x":"")}
{f=$1<0; printf "%s", $0}
END {print ""}' file
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.