date está dizendo data inválida [duplicata]

1

Atualmente, tenho um arquivo de texto delimitado por tabulações formatado assim:

David   Webb    Box 34 Rural Route 2    Nixa    MO  65714   (417)555-1478   555-66-7788 09-13-1970
Martha  Kent    1122 North Hwy 5    Smallville  KS  66789   (785)555-2322   343-55-8845 04-17-1965
Edward  Nygma   443 W. Broadway Gotham City NJ  12458   (212)743-3537   785-48-5524 08-08-1987

Estou tentando formatar as datas como September 13, 1970 em vez de 09-13-1970

O que eu tenho tentado fazer é cut -f 9 file > tmpfile e depois usar

date -f tmpfile "+%B %d, %Y" > date

mas continua dizendo

date: invalid date ‘09-13-1970’
date: invalid date ‘04-17-1965’
date: invalid date ‘08-08-1987’

o que estou fazendo de errado?

    
por Jon Butler 14.02.2017 / 05:47

2 respostas

2

A data não aceita esse formato de entrada, tente colocar o ano primeiro, como o fluxo editando a entrada:

cut -f 9 file | sed 's/\(..\)-\(..\)-\(....\)/--/' > tmpfile

Teste manual:

$ date --date '09-13-1970' "+%B %d, %Y"
date: invalid date ‘09-13-1970’

$ date --date '09/13/1970' "+%B %d, %Y"
September 13, 1970

$ date --date '1970/09/13' "+%B %d, %Y"
September 13, 1970

$ date --date '1970-09-13' "+%B %d, %Y"
September 13, 1970
    
por 14.02.2017 / 06:28
2

Aqui está uma versão usando o awk, que não requer um arquivo intermediário.

#!/bin/awk -f
BEGIN {FS="\t"; OFS="\t"}
{
    split($9,A,"-");
    S1 = sprintf("%d %d %d 0 0 0",A[3],A[1],A[2])
    D1 = strftime("%B %d, %Y", mktime(S1))
    $9 = D1
    print
}
    
por 14.02.2017 / 06:24