2011-01-10 2 views
15

Ich habe eine Datei von 3 Feldern:prüfen Feldlänge mit awk

123710337783,351898014413150,123028040249634 
123710337785,352934028758390,123028040109275 

Ich muss überprüfen, ob die Felder folgende Längen erfüllen:

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

ich eine Fehlermeldung erhalten, wenn dieser ausgeführt wird:

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

Bitte assistieren.

Bernie

+2

Was ist der Fehler, den Sie bekommen? –

Antwort

13

Alle Ihre Klammern sind nicht übereinstimmend. ‚Wenn‘ Ausdruck muss in Klammern enthalten sein, das heißt,

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

Sie diese nicht hat, und Sie haben mehr Schließen Klammer bekommen als Klammer öffnen - so die Waage ausgeschaltet ist, wie gut; wenn wir die Klammern (Schrittweite für offene, Dekrement für schließen) zählen, haben wir am Ende mit insgesamt -3 anstelle von 0, also drei Klammern schließen, als wir geöffnet haben:

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

Also, versuchen Sie stattdessen die wieder ins Gleichgewicht bringt alles:

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

Sie haben nicht übereinstimmen/unsymmetrisch Klammer in an Bedingungen geknüpft. Versuchen Sie:

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

Wenn alles, was Sie tun werden Druck ist, dann ist Ihr Ausdruck als Standardzustand versetzt:

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

Wenn Sie versuchen, in Ihrem Eingang zum ausfiltern von Linien Datei, die t nicht erfüllt sein Kriterium:

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