Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2322786
  • 博文数量: 535
  • 博客积分: 8689
  • 博客等级: 中将
  • 技术积分: 7066
  • 用 户 组: 普通用户
  • 注册时间: 2010-11-26 10:00
文章分类

全部博文(535)

文章存档

2024年(4)

2023年(4)

2022年(16)

2014年(90)

2013年(76)

2012年(125)

2011年(184)

2010年(37)

分类: 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`

 






用Linux shell 计算两个时间差

2011-11-29 11:06 | 分类: | 浏览2230次
在日志中有两条记录
                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 命令计算出:(结束时间 - 开始时间)的秒数?
提问者采纳
2011-11-29 11:24
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
}'

阅读(1308) | 评论(0) | 转发(0) |
0

上一篇:samba配置

下一篇:Solaris 10 配置ip地址过程

给主人留下些什么吧!~~