我有一个 bash 脚本,它将进入一个文件夹并通过匹配键字符串来提取时间戳。然后它将日期和时间戳s转换为标准格式,并在两个时间戳s之间进行减法,然后返回输出值。该脚本正在运行,但问题是输出错误。
我的脚本:
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
如果您是前 2 个变量 TDS,TDE 是从 .log 文件中提取的变量(我已经手动验证了它们并且它们是正确的)。基于这些值,TotalDuration 应该等于 00:23:02,但脚本将 TotalDuration 指定为 01:23:02。
有人可以帮我找出我的错误并指导我解决问题以获得正确的结果。
将
-u
标志添加到您的 date 命令以获得正确的输出。请注意,这应该是 00:23:02 而不是 00:22:62。-u
以 UTC 格式打印时间。