
Eu tenho um script de shell Unix que gera saída de um log.
for i in HistSimBasislieferung hedgeAccountingF4PublicSend;do
report1=$(echo -n $i:)
date1=$(grep -e $i $PALME_CONF | grep "The job finished" | tail -1 | awk '{print $1,$2}'|\<br/> sed 's/^.\(.*\).$/\1/')
final="$report1 $date1"
echo "$final"
done
No momento a saída está assim:
HistSimBasislieferung 2015-03-11 01:03:02
hedgeAccountingF4PublicSend 2015-03-11 00:16:34
Mas o que eu quero é algo assim:
HistSimBasislieferung,hedgeAccountingF4PublicSend
2015-03-11 01:03:02,2015-03-11 00:16:34
Você tem alguma sugestão sobre como isso pode ser feito?
Fiz do jeito que você sugeriu:
for i in HistSimBasislieferung hedgeAccountingF4PublicSend;do
echo -n $i > report_log
grep -e $i $PALME_CONF | grep "The job finished" | tail -1 | awk '{print $1,$2}' | sed 's/^.\(.*\).$/\1/' > date_log
done
cat < report_log | xargs echo | tr ' ' ',';
cat < date_log | xargs echo | tr ' ' ',';
echo "" > report_log; echo "" > date_log
mas a saída deu:
hedgeAccountingF4PublicSend2015-03-11,00:16:34
I need it like this:
HistSimBasislieferung,hedgeAccountingF4PublicSend,
2015-03-11 03:05:40,2015-03-11 02:12:19,
Responder1
Este forro pode parecer feio, mas acho que funciona (se entendi seu caso de uso corretamente).
your_shell_script.sh | cut -d ' ' -f 1 | tr '\n' ',' | sed 's/,$/\n/'; your_shell_script.sh | cut -d ' ' -f '2-' | tr '\n' ',' | sed 's/,$/\n/'
Responder2
É um script de loop, portanto substituirá a variável a cada loop. Minha sugestão aqui é criar um arquivo de log para o "relatório" e um arquivo de log para "data" também (anexar log).
No final do seu script (logo abaixo da linha “concluído”), execute o comando abaixo:
cat <\report_log_file> | xargs echo | tr ' ' ',';
cat <\date_log_file> | xargs echo | | tr ' ' ','
ou crie outro script de loop.
for i in <\report_log_file> <\date_log_file>; do
cat $i | xargs echo | tr ' ' ',';
done
em seguida, limpe os arquivos de log:
echo "" > report_log_file; echo "" > date_log_file