免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 9216 | 回复: 7
打印 上一主题 下一主题

[日期时间] 如何在shell中实现两个时间相减并输出相差的小时数 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-12-26 14:03 |只看该作者 |倒序浏览
如题。想在程序中查看一段代码的运行时间,在开始时取得日期和时间,结束后再取一次,进行相减,希望得到相差几个小时。

论坛徽章:
33
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年纪念徽章
日期:2019-08-20 08:30:3720周年集字徽章-周	
日期:2020-10-28 14:13:3020周年集字徽章-20	
日期:2020-10-28 14:04:3019周年集字徽章-CU
日期:2019-09-08 23:26:2519周年集字徽章-19
日期:2019-08-27 13:31:262016科比退役纪念章
日期:2022-04-24 14:33:24
2 [报告]
发表于 2013-12-26 14:19 |只看该作者
  1. time
复制代码

论坛徽章:
1
未羊
日期:2014-01-02 10:31:18
3 [报告]
发表于 2013-12-26 14:23 |只看该作者
BEGINTIME=`date +%R|sed 's/:.*//'`
...
...
ENDTIME=`date +%R|sed 's/:.*//'`

TIME=`expr  $ENDTIME - $BEGINTIME`

初学者,不知道写得对不对~~

论坛徽章:
8
技术图书徽章
日期:2013-08-22 11:21:28未羊
日期:2015-01-19 22:22:25巳蛇
日期:2014-08-11 16:53:08子鼠
日期:2014-05-29 09:04:44摩羯座
日期:2014-04-11 14:15:07丑牛
日期:2014-01-24 12:41:28金牛座
日期:2013-11-21 17:38:28射手座
日期:2015-01-21 08:50:32
4 [报告]
发表于 2013-12-26 14:24 |只看该作者
  1. => cat jindu.sh
  2. #!/bin/bash

  3. st=`date +%s` #记录开始
  4. b=''
  5. for ((i=0;$i<=100;i+=2))
  6. do
  7.     printf "progress:[%-50s]%d%%\r" $b $i
  8.     sleep 0.1

  9.     b=#$b
  10. done
  11. echo

  12. en=`date +%s`  #记录结尾
  13. min=`awk -ven=$en -vst=$st 'BEGIN{print (en-st)/60}'` #计算
  14. echo "it use $min minutes"
复制代码
  1. => sh jindu.sh
  2. progress:[##################################################]100%
  3. 5
复制代码

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:58:11
5 [报告]
发表于 2013-12-26 14:31 |只看该作者
  1. [root@everIover ~]# start_time=$(date -d "20131225" +%s) #为了更好的测试 可以把d 参数去掉,这starttime是 20131225 00:00:00
  2. [root@everIover ~]# end_time=$(date +%s)#当前时间
  3. [root@everIover ~]# echo "($end_time-$start_time)/(60*60)"|bc
  4. 38
  5. [root@everIover ~]#
复制代码

论坛徽章:
0
6 [报告]
发表于 2013-12-26 16:46 |只看该作者
可以用变量吗回复 5# 这个冬天不冷


   

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:58:11
7 [报告]
发表于 2013-12-26 17:25 |只看该作者
  1. shell中 只要echo 能输出的东西 都能赋给一个变量
复制代码

论坛徽章:
1
未羊
日期:2014-01-02 10:31:18
8 [报告]
发表于 2013-12-26 20:22 |只看该作者
本帖最后由 huzikan 于 2013-12-26 20:25 编辑

正解
     
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP