mudança de formato de data no comando awk

1

Eu tenho um arquivo mdn.txt com o seguinte registro de amostra.

mdn.txt:

123456,2711448,1,20150214092425,20150714092425,120,20150814163821,,123,,,123,20150214092425,,123,,,123,20150214092425,,123,Y

Agora quero processar todos os registros do meu arquivo por awk e quero alterar o formato do campo de data, como abaixo:

123456,2711448,1,14-02-2015 09:24:25,14-07-2015 09:24:25,120,14-08-2015 16:38:21,,123,,,123,14-02-2015 09:24:25,,123,,,123,14-02-2015 09:24:25,,123,Y

A entrada de dados é, portanto, dígitos com ( Y ouvido, M onth, D ay, H nosso, M inute, S econd)

YYYYMMDDHHMMSS

O resultado deve ser:

DD-MM-YYYY HH:MM:SS
    
por user3548033 19.08.2015 / 16:36

3 respostas

3
awk 'BEGIN{ FS=OFS="," 
            n=split("4,5,7,13,19", f)   # array of input field numbers
     }
     { for(i=1; i<=n; i++) if($f[i]) $f[i] = dconv($f[i]); print 
     }
     function dconv(x) {
       YY=substr(x, 1, 4)
       mm=substr(x, 5, 2)
       dd=substr(x, 7, 2)
       hh=substr(x, 9, 2)
       nn=substr(x,11, 2)
       ss=substr(x,13, 2)
       return dd"-"mm"-"YY" "hh":"nn":"ss  
     }' file

Abaixo, é (fundamentalmente) o mesmo script, com mais uma matriz (e sem a função)

awk 'BEGIN{ FS=OFS=","
            nf=split("4,5,7,13,19", f)                           # array of input field numbers
            nd=split(",7,2,-,5,2,-,1,4, ,9,2,:,11,2,:,13,2", d)  # array of date subfield info (in output order): prefix(out),pos(in),len(in)         
     }
     { for(i=1; i<=nf; i++){ 
           if($f[i]) {
               fmod=""
               for(j=1; j<=nd; j+=3) fmod=fmod sprintf("%s", d[j] substr($f[i], d[j+1], d[j+2]))
               $f[i] = fmod
           }
       } print
     }' file
    
por 19.08.2015 / 17:32
1

Em seguida, você converterá qualquer campo de 14 dígitos:

awk -F, ' function form(E){
              $E=substr($E,1,4) "-" substr($E,5,2) "-" substr($E,7,2) " "\
                 substr($E,9,2) ":" substr($E,11,2) ":" substr($E,13)
        }
        { for(i=1;i<=NF;i++)
              if($i ~ /[0-9]{14}/)
                  form(i)
          print
        }' OFS=, mdn.txt
    
por 19.08.2015 / 18:54
-1

Se a string de origem for mantida na variável s, você poderá usar printf e substr ie

printf ("% 2d-% 2d-% 4d% 2d:% 2d:% 2d", substr (s, 7,2), substr (s, 5,2), substr (s, 1,4) , substr (s, 9,2), substr (s, 11,2), substr (s, 13,2))

    
por 20.08.2015 / 12:49