
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
}'
1、按照YYYY-YY-DD的格式显示当前日期
2、按照MM/DD/YY的格式显示当前日期
3、计算3天前的日期
4、计算3天后的日期
5、计算1个月前的日期
6、计算1年前的日期
7、获取当前时间
8、获取1小时前的时间
9、获取10分钟前的时间
10、显示系统当前的时间戳,基准是格林尼治天文台1970年1月1日0点0分0秒
11、把某时间戳转换回日期格式
date -d "@1614679748"
2020年 03月 02日 星期六 18:09:08 CST
12、计算任意日期的后N日
13、计算两个日期相差天数
#include <stdio.h>#include <time.h>
int
main ()
{
struct tm tm, tm2
char buf[255]
time_t t1, t2
strptime ("Thu Feb 5 13:12:18 EST 2009", "%a %b %d %H:%M:%S EST %Y", &tm)
strptime ("Fri Feb 6 13:11:18 EST 2009", "%a %b %d %H:%M:%S EST %Y", &tm2)
t1 = mktime(&tm)
t2 = mktime(&tm2)
printf("TIME: %ld, %ld, %ld\n", t2, t1, t2-t1)
return 0
}
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)