grep 文件中的时间戳,如下所示。现在我需要计算时差
文件数据:
18:29:10
04:56:50
我尝试执行以下命令,其输出为负值:
awk -F":" 'FNR==1{split($0,a,":");sec1=a[1]*3600+a[2]*60+a[3]} FNR==2{split($0,b,":");sec2=b[1]*3600+b[2]*60+b[3];val=sec2-sec1;ho=int(val/3600);val=val%3600;mi=sprintf("%02d",(val/60));val=val%60;;print ho":"mi":"val}' file.txt
输出为:-13:-32:-10
我想要的输出如下:10:27:40
答案1
使用 GNU 日期:
string1="18:29:10"
string2="04:56:50"
StartDate=$(date -u -d "$string1" +"%s")
FinalDate=$(date -u -d "$string2" +"%s")
date -u -d "0 $FinalDate sec - $StartDate sec" +"%H:%M:%S"
输出:
10:27:40
答案2
假设您的意思是 10:27:40
awk -F: '
{t[NR] = $3 + 60 * ($2 + 60 * $1)}
END{
d = t[2] - t[1]
if (d < 0) d += 86400
h = d / 3600
d %= 3600
m = d / 60
s = d % 60
printf "%02d:%02d:%02d\n", h, m, s
}'
答案3
只是为了好玩,使用dc
:
$ cat file.txt
18:29:10
04:56:50
$ tr : \ <file.txt | dc -f - -e 'r60*+r60d**+r-r60*-r60d**-60dod24**+p'
10 27 40
$
这是我的第一个dc
剧本。有趣的学习体验。
另一种方法使用dc
:
$ cat file.txt
18:29:10
04:56:50
$ cat time_subtract.dc
[r60*+r60d**+]sb60d24**sd[ld+d0>n]snlbxsflbx_1*lf+60od0>np
$ tr : \ <file.txt | dc -f - -f time_subtract.dc
10 27 40
$
最后,很好地封装在 shell 脚本中,以便它可以作为./script.sh file.txt
或运行some pipeline | ./script.sh
,我们有:
#!/bin/sh
cat "$@" |
tr : ' ' |
dc -e '
[60+Lm1-Sm]SS
[60+Lh1-Sh]SM
[24+]SH
?SsSmSh
?SsSmSh
LsLs- d0>S Ss
LmLm- d0>M Sm
LhLh- d0>H Sh
[
]Ls[:]Lm[:]Lh
nnnnnn
'