用Linux shell 计算两个时间差

在日志中有两条记录id开始时间结束时间000485e7db1236cfc0d91f29c555af5e2011-11-2815:55:372011-11-2815:55:... 在日志中有两条记录
id 开 始 时 间 结 束 时 间
000485e7db1236cfc0d91f29c555af5e 2011-11-28 15:55:37 2011-11-28 15:55:52
00049dc21b0a7dca98548c875354f77f 2011-11-28 16:21:01 2011-11-28 16:21:23
如何用linux shell 命令计算出:(结束时间 - 开始时间)的秒数?
展开
 我来答
luneng8183
推荐于2017-11-24 · TA获得超过902个赞
知道小有建树答主
回答量:606
采纳率:100%
帮助的人:512万
展开全部
start=`date +%s -d "2011-11-28 15:55:37"`
end=`date +%s -d "2011-11-28 15:55:52"`
echo $(($end-$start))

这个前提是你能拿到开始和结束时间字串的基础上的。

如果你的日志文件输出格式是上述的话,还有个方法:
cat 日志文件 | awk '/^000/{
start=$2 " " $3
end=$4 " " $5

stm=mktime(gensub(/[:-]/, " ", "g", start))
etm=mktime(gensub(/[:-]/, " ", "g", end))

print $1 " - " etm-stm
}'
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式