Como subtrair datas da coluna usando o awk?

1

Eu tenho três colunas assim:

18:37:12 18:37:31 0  
18:37:01 18:37:18 0

Gostaria que a terceira coluna fosse preenchida com a diferença em segundos das duas primeiras colunas assim:

18:37:12 18:37:31 19  
18:37:01 18:37:18 17

Estou usando isso:

nova migration-list | grep completed | awk '{ print substr($22,12,8), substr($24,12,8) }' | awk 'BEGIN{ FS=" " } { print $0, $2-$1 }'

Agradeço qualquer ajuda

    
por Andre 21.10.2016 / 20:38

2 respostas

0

Em um sistema GNU:

awk '{"date -d "$1" +%s"|getline one; "date -d "$2" +%s"|getline two; \
         print $1, $2, two-one}' file.txt
  • "date -d "$1" +%s"|getline one obtém os segundos desde a época (usando o GNU date ) para o campo 1, salve na variável one

  • "date -d "$2" +%s"|getline two faz o mesmo para o campo 2 e salva o resultado como variável two

  • print $1, $2, two-one imprime o campo um, dois e subtração da variável dois e um

Exemplo:

% cat file.txt
18:37:12 18:37:31 0
18:37:01 18:37:18 0

% awk '{"date -d "$1" +%s"|getline one; "date -d "$2" +%s"|getline two; print $1, $2, two-one}' file.txt
18:37:12 18:37:31 19
18:37:01 18:37:18 17
    
por 21.10.2016 / 20:43
1

Usando as funções de tempo embutido do GNU awk:

awk '
  function to_time(time,   t,a) {
    split(time, a, ":")
    t = mktime("1970 1 1 " a[1] " " a[2] " " a[3])
    return t
  }
  {print $1, $2, to_time($2) - to_time($1)}
' file
    
por 21.10.2016 / 21:06