我有一个 bash 脚本,它会进入文件夹并通过匹配键字符串来提取时间戳。然后它会将日期和时间戳转换为标准格式,并在两个时间戳之间执行减法,然后返回输出值。该脚本可以运行,但问题是我得到了错误的输出。
我的脚本:
cd /data/version1/logs/log_Job_7702260850557985265/
{
TDS="$(grep 'Logfile started' manoj.log | awk '{print $3,$4}' | cut -d: -f2-)"
echo "$TDS"
TDE="$(grep 'Process removed' manoj.log | awk '{print $1,$2}')"
echo "$TDE"
convert_date(){ printf '%s-%s-%s %s' ${1:6:4} ${1:3:2} ${1:0:2} ${1:11:8}; }
# Convert to timestamp
TDS_TS=$(date -d "$(convert_date "$TDS")" +%s)
echo "$TDS_TS"
TDE_TS=$(date -d "$(convert_date "$TDE")" +%s)
echo "$TDE_TS"
# Subtract
TD=$((TDE_TS-TDS_TS))
echo "$TD"
# convert to HH:MM:SS (note, that if it's more than one day, it will be wrong!)
TotalDuration=$(date -d "@$TD" +%H:%M:%S)
echo "$TotalDuration"
}
以下是所有变量的输出:
TDS = 21.07.2019 05:04:50
TDE = 21.07.2019 05:27:52
TDS_TS = 1563678290
TDE_TS = 1563679672
TD = 1382
TotalDuration = 01:23:02
如果您使用前两个变量 TDS、TDE,则它们是从 .log 文件中提取的变量(我已手动验证它们并且它们是正确的)。根据这些值,TotalDuration 应该等于 00:23:02,但脚本给出的 TotalDuration 为 01:23:02。
有人能帮助我找出我的错误并指导我解决问题以获得正确的结果吗?
答案1
将标志添加-u
到您的日期命令中以获取正确的输出。请注意,这应该是 00:23:02,而不是 00:22:62。
TotalDuration=$(date -ud "@$TD" +%H:%M:%S)
-u
以 UTC 格式打印时间。