使用awk检查字段长度

时间:2011-01-10 16:15:36

标签: awk field

我有一个包含3个字段的文件:

123710337783,351898014413150,123028040249634
123710337785,352934028758390,123028040109275

我需要检查字段是否符合以下长度:

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

运行时遇到错误:

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

请协助。

伯尼

3 个答案:

答案 0 :(得分:17)

您的所有括号都不匹配。 'if'表达式必须包含在括号内,即

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

你没有这个,并且你有更多的关闭括号而不是开括号 - 所以平衡也是关闭的;如果我们计算括号(开放的增量,关闭的减量),我们最终得到的总数为-3而不是0,所以关闭三个括号比我们打开的更多:

            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  }'

所以,试试这个,重新平衡一切:

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

答案 1 :(得分:8)

如果您要做的就是打印,那么将表达式作为默认条件:

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

如果您尝试过滤输入文件中不符合此条件的行:

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

答案 2 :(得分:5)

条件中有不匹配/不平衡的括号。尝试:

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