助けを求めるスクリプトを書いています。私のスクリプトでは、次の日付形式を使用しています(YYYY MM DD HH MM)。
$ echo $DT
202002252216
私の要件は、ファイルにリストされている2つの日付を比較し、出力を時間単位で計算することです。
cat /home/postgres/pglinux_mm_cfg
MM_START=202002261015
MM_END=202002261530
MM_SERVER=pglinux
これは私のスクリプトです。timediff.sh
ENV=/home/postgres
MM_START=`grep MM_START ${ENV}/\`hostname\`_mm_cfg |awk -F"=" '{print $2}'`
MM_END=`grep MM_END ${ENV}/\`hostname\`_mm_cfg |awk -F"=" '{print $2}'`
MPHR=60
STARTIME=$(date +%Y%m%d%H%M -d ${MM_START})
ENDTIME=$(date +%Y%m%d%H%M -d ${MM_END})
MINUTES=$(( ($ENDTIME - $STARTIME) / $MPHR ))
echo $STARTIME $ENDTIME $MINUTES
MM_ENDとMM_STARTの日付と時刻の違いを取得するには?
を使用していますksh
。
ベストアンサー1
これは望むものではないかもしれませんが、適切なプログラミング言語を使用する方がはるかに簡単です。 PHPを例に挙げましょう。
<?php
$o1 = date_create('202002261015');
$o2 = date_create('202002261530');
$o3 = date_diff($o2, $o1);
echo 'days: ', $o3->d, ', hours: ', $o3->h, "\n";
結果:
days: 0, hours: 5