开发者

Check field length using awk

开发者 https://www.devze.com 2023-02-04 12:07 出处:网络
I have a file of 3 fields: 123710337783,351898014413150,12302804024963开发者_如何学运维4 123710337785,352934028758390,123028040109275

I have a file of 3 fields:

123710337783,351898014413150,12302804024963开发者_如何学运维4
123710337785,352934028758390,123028040109275

I need to check that the fields meet the following lengths:

Field 1 = 12
Field 2 = 15 or 16
Field 3 = 15

I get an error when running this:

awk -F, '{if(length($2) == 15 ) || length($2) == 16) && length($1) == 12 && length($3)) == 15) print  }'

Please assist.

Bernie


All your brackets are mismatched. An 'if' expression must be contained within brackets, i.e.,

if (X == 45) ...
if ((X == 45) || (Y == 23)) ...

you don't have this, and you've got more closing brackets than opening brackets - so the balance is off as well; if we count the brackets (increment for open, decrement for close), we end up with a total of -3 instead of 0, so closing three more brackets than we have open:

            1      2  1       0          1  0     -1          0 -1                0 -1 -2     -3
awk -F, '{if(length($2) == 15 ) || length($2) == 16) && length($1) == 12 && length($3)  ) == 15) print  }'

So, try this instead which rebalances everything:

awk -F, '{ if (((length($2) == 15 ) || length($2) == 16) && (length($1) == 12 && length($3) == 15)) print }'


If all you're going to do is print, then put your expression as the default condition:

awk -F, 'length($1)==12 && (length($2)==15 || length($2)==16) && length($3)==15'

If you're trying to filter out lines in your input file that don't meet this criteria:

awk -F, '
    length($1)!=12 || length($2)<15 || length($2)>16 || length($3)!=15) {next}
    # do other stuff...
'


You have mismatched/unbalanced parenthesis in conditional. Try:

{ if ((length($2) == 15 || length($2) == 16) && length($1) == 12 && length($3) == 15) print; }
0

精彩评论

暂无评论...
验证码 换一张
取 消