bash – 使用Unix / Linux中的命令行来跟踪时间的日期和时间计算
发布时间:2020-12-16 01:30:27 所属栏目:安全 来源:网络整理
导读:我正在寻找一种简单的方法来跟踪我在使用命令行的项目上工作的时间.我做 echo "$(date) : Start" worktime.txt 当我开始工作和 echo "$(date) : End" worktime.txt 当我停止工作结果是一个形式的文件: kent@rat:~/work$cat worktime.txt Fri Jan 2 19:17:13
我正在寻找一种简单的方法来跟踪我在使用命令行的项目上工作的时间.我做
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等. 所有想法欢迎!
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 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |