当前位置:  开发笔记 > 编程语言 > 正文

在Unix/Linux中使用命令行跟踪时间的日期和时间计算

如何解决《在Unix/Linux中使用命令行跟踪时间的日期和时间计算》经验,为你挑选了2个好方法。

我正在寻找一种简单的方法来跟踪我使用命令行处理项目的时间.我做

echo "$(date) : Start" >>worktime.txt

当我开始工作时

echo "$(date) : End" >>worktime.txt

当我停止工作.结果是以下形式的文件:

kent@rat:~/work$ cat worktime.txt 
Fri Jan  2 19:17:13 CET 2009 : Start
Fri Jan  2 19:47:18 CET 2009 : End
Fri Jan  2 21:41:07 CET 2009 : Start
Fri Jan  2 22:39:24 CET 2009 : End

"开始"和"结束"是指描述,可以是任何其他文本.可以肯定的是,每个奇数行包含之前的开始日期和时间:并且每个偶数行包含结束日期和时间.

我想要做的是通过使用bash,tr,sed,awk和其他常见的Unix/Linux工具解析文本文件来总结我的工作时间.我更喜欢使用这种方法,而不是使用Python,Perl,Haskell,Java等.

欢迎所有想法!



1> wilhelmtell..:

假设您正在使用GNU coreutils,请date +%s改为运行.

echo $(date +%s) : Start

%s占位符与非POSIX兼容,并且特定于GNU日期.它被自纪元以来经过的秒数所取代.接下来编写一个记录差异并加以总结的脚本.你会做点什么的

#!/bin/bash

total=0
while read LINE; do
  t1=$(echo $LINE |cut -d' ' -f1)
  read LINE
  t2=$(echo $LINE |cut -d' ' -f1)
  total=$(($total+$t2-$t1))
done
echo "$(echo "scale=2; $total/(60*60)" |bc -l)" hours

如果调用脚本sum_time.sh,则可以使用调用脚本

~$ ./sum_time.sh



2> Jehiah..:

wilhelmtell有一个很好的脚本,如果你需要使用一个稍微修改过的版本,这样你可以继续使用$(date)而不是$(date +%s)这个将以相同的方式工作,只需添加一行来重新格式化时间使用+%s

#!/bin/bash
total=0
while read LINE; do
  d1=$(echo $LINE |cut -c1-28);
  t1=$(date -d "$d1" +%s);
  read LINE
  d2=$(echo $LINE |cut -c1-28);
  t2=$(date -d "$d2" +%s);
  total=$(($total+$t2-$t1));
done
echo $(($total/(60*60))) hours

推荐阅读
小妖694_807
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有