Alterar formato de hora em um arquivo

1

Eu tenho a saída de um comando sar e a hora não é POSIX:

Linux 2.6.32-431.29.2.el6.x86_64 (test.server.com)  2015-08-01  _x86_64_    (32 CPU)

12:00:01 AM     CPU      %usr     %nice      %sys   %iowait    %steal      %irq     %soft    %guest     %idle
12:10:01 AM     all      0.01      0.00      0.07      0.00      0.00      0.00      0.00      0.00     99.93
12:10:01 AM       0      0.01      0.00      0.02      0.00      0.00      0.00      0.00      0.00     99.97
[…]

Estou tentando descobrir como substituir o horário de 12:00:01 AM em posix 00:00:01 em linhas que começam com o tempo.

Alguma idéia?

Muito obrigado!

    
por Warnaud 07.09.2015 / 10:17

2 respostas

2

Pessoalmente, eu faria assim:

  • analise a hora no formato de época.
  • imprima a hora da época no formato de saída desejado.

Por exemplo assim:

#!/usr/bin/env perl

use strict;
use warnings;

use Data::Dumper;
use Time::Piece; 

while ( <DATA> ) {
   my ( $time_str ) = m/^([\d\:]+ [AP]M)/;
   print $time_str, "=>",;
   my $newtime = Time::Piece -> strptime ( $time_str, "%I:%M:%S %p" );
   print $newtime->strftime("%H:%M:%S"),"\n";
}

__DATA__
12:00:01 AM     CPU      %usr     %nice      %sys   %iowait    %steal      %irq     %soft    %guest     %idle
12:10:01 AM     all      0.01      0.00      0.07      0.00      0.00      0.00      0.00      0.00     99.93
12:10:01 AM       0      0.01      0.00      0.02      0.00      0.00      0.00      0.00      0.00     99.97

Qual seria o seu script:

#!/usr/bin/env perl

use strict;
use warnings;

use Time::Piece;

while (<>) {
    if ( my ($time_str) = m/^([\d\:]+ [AP]M)/ ) {
        my $new_time_str = Time::Piece->strptime( $time_str, "%I:%M:%S %p" )
            ->strftime("%H:%M:%S");
        s/$time_str/$new_time_str/;
    }
    print;
}

Isso funciona "inline" - <> é a mágica do perl para permitir que você:

  • ./myscript.pl some_file
  • some_command | ./myscript.pl

Provavelmente, pode-se linerificar isso como:

perl -MTime::Piece -pe 's/^([\d\:]+ [AP]M)/Time::Piece->strptime( $1, q{%I:%M:%S %p} )->strftime(q{%H:%M:%S})/e;'
    
por 07.09.2015 / 10:31
0

Observe que em arquivos futuros você pode obter a saída no formato de 24 horas limpando sua localidade, que é presumivelmente en_US ou similar, e é por isso você está recebendo AM / PM. Por exemplo:

$ LANG=C sar -u 2 5
13:32:30        CPU     %user     %nice   %system   %iowait    %steal     %idle

enquanto

$ LANG=en_US sar -u 2 5
01:32:02 PM     CPU     %user     %nice   %system   %iowait    %steal     %idle
    
por 07.09.2015 / 13:35