全部博文(535)
分类: LINUX
2013-05-23 09:35:05
最近一段时间,在处理Shell 脚本时候,遇到时间的处理问题。 时间的加减,以及时间差的计算。
1。 时间加减
这里处理方法,是将基础的时间转变为时间戳,然后,需要增加或者改变时间,变成 秒。
如:1990-01-01 01:01:01 加上 1小时 20分
处理方法:
a.将基础时间转为时间戳
time1=$(date +%s -d '1990-01-01 01:01:01')
echo $time1
631126861 【时间戳】
b.将增加时间变成秒
[root@localhost ~]# time2=$((1*60*60+20*60))
[root@localhost ~]# echo $time2
4800
c.两个时间相加,计算出结果时间
time1=$(($time1+$time2))
time1=$(date +%Y-%m-%d\ %H:%M:%S -d "1970-01-01 UTC $time1 seconds");
echo $time1
1990-01-01 02:21:01
2。时间差计算方法
如:2010-01-01 与 2009-01-01 11:11:11 时间差
原理:同样转成时间戳,然后计算天,时,分,秒
time1=$(($(date +%s -d '2010-01-01') - $(date +%s -d '2009-01-01 11:11:11')));
echo time1
将time1 / 60 秒,就变成分了。
补充说明:
shell 单括号运算符号:
a=$(date);
等同于:a=`date`;
双括号运算符:
a=$((1+2));
echo $a;
等同于:
a=`expr 1 + 2`
在日志中有两条记录 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 命令计算出:(结束时间 - 开始时间)的秒数?
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 }'