Como comparar variáveis flutuantes no awk?

0
awk -F, 'NR==FNR{c[$29]=$29;next} NF{print $29 ((c[$29]==$29)?" ":",mismatch")}' $file1 $file2

O valor do 29º campo, ou seja, $ 29 no arquivo1 era 832,9 e o do arquivo2 era 832,9000. Se eu compará-los, eles não são iguais. Eu acho que está tomando como uma string em vez de um número.

Como devo proceder?

    
por Ramana Reddy 20.04.2015 / 13:38

1 resposta

3

awk compara os números de ponto flutuante:

Acabei de escrever um novo script:

paste \
    <(awk -F, '{print $29}' file1 ) \
    <(awk -F, '{print $29}' file2 ) \
    | awk '{print $1; print $2; print ($1==$2)?"match" :"mismatch"}'

Se você não gosta de intervalos, use printf em vez de print.

Exemplo

Arquivos de entrada

cat file1

12,2,12,12,12,12,3,2,53,6,5474,346,567,6578,89,7689,7,987,69869,1,4,5,4,3,4,2,6,21,832.9,9,2
12,2,12,12,12,12,3,2,53,6,5474,346,567,6578,89,7689,7,987,69869,1,4,5,4,3,4,2,6,21,12.329,9,2

cat file2

12,2,12,12,12,12,3,2,53,6,5474,346,567,6578,89,7689,7,987,69869,1,4,5,4,3,4,2,6,21,832.9000,9,2
12,2,12,12,12,12,3,2,53,6,5474,346,567,6578,89,7689,7,987,69869,1,4,5,4,3,4,2,6,21,832.9000,9,2

Saída

% paste <(awk -F, '{print $29}' file1 ) <(awk -F, '{print $29}' file2 ) | awk '{print $1; print $2; print ($1==$2)?"match" :"mismatch"}'

832.9
832.9000
match
12.329
832.9000
mismatch
    
por A.B. 20.04.2015 / 14:21