2011-01-10 21 views
15

Tengo un archivo de 3 campos:Comprobar la longitud del campo usando awk

123710337783,351898014413150,123028040249634 
123710337785,352934028758390,123028040109275 

Tengo que comprobar que los campos se encuentran las siguientes longitudes:

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

me sale un error cuando se ejecuta este:

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

Asistencia.

Bernie

+2

¿Cuál es el error que obtienes? –

Respuesta

13

Todos sus soportes no coinciden. Un 'si' expresión debe estar contenida dentro de corchetes, es decir,

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

usted no tiene esto, y tienes más escuadras de cierre de la apertura de corchetes - por lo que el equilibrio está fuera así; si contamos los soportes (incremento de abierta, de disminución para cerrar), que terminan con un total de -3 en lugar de 0, por lo que el cierre de tres soportes más de lo que tenemos abierta:

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

lo tanto, tratar este lugar lo que reequilibra todo:

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

Usted tiene paréntesis no coincidentes/no balanceado en condicional. Pruebe:

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

Si todo lo que vamos a hacer es imprimir, a continuación, poner su expresión como la condición por defecto:

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

Si usted está tratando de filtrar las líneas en su entrada archivo que no cumple t sus criterios:

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