2011-01-10 17 views
15

Mam plik z 3 dziedzin:Sprawdź długość pola za pomocą awk

123710337783,351898014413150,123028040249634 
123710337785,352934028758390,123028040109275 

muszę sprawdzić, że pola spełniać następujące długości:

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

pojawia się błąd, gdy uruchomiony w ten sposób:

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

Proszę o pomoc.

Bernie

+2

Jaki jest błąd? –

Odpowiedz

13

Wszystkie zamki są niedopasowane. Za „czy” wyrażenie musi być zawarte w nawiasach, to znaczy

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

nie masz to i masz więcej niż otwarcie klamry zamykające nawiasy - więc bilans jest także wyłączyć; jeśli liczymy wsporniki (przyrost o otwarte, ubytek na zamknięciu), skończymy w sumie -3 zamiast 0, więc zamykając kolejne trzy wsporniki niż mamy otwarte:

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

Tak, spróbuj zamiast tego który przywraca równowagę wszystko:

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

masz niedopasowane/niesymetryczne nawias w warunkowy. Wypróbuj:

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

Jeśli wszystko, co zamierzamy zrobić, to wydrukować, a następnie umieścić swój wyraz jako domyślny stan:

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

Jeśli chcesz odfiltrować wiersze w swoim wejściu plik, który nie spełnia t jego kryteria:

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