我有一个文件
a 10:10 10:30
b 12:15 13:15
c 16:54 17:54
例如,我需要输入间隔,10:15
所以我的输出应该是a 10:10 10:30
我需要如何使用awk
?
答案1
1)分别比较小时和分钟:
awk -vt="10:15" -F"[: ]" '
BEGIN{split(t,a,":")}
$2<=a[1]&&$3<=a[2]&&$4>=a[1]&&$5>=a[2]
' <<_INPUT_
a 10:10 10:30
b 12:15 13:15
c 16:54 17:54
_INPUT_
a 10:10 10:30
2)将小时转换为分钟:
awk -vt="13:00" -F"[: ]" '
BEGIN{split(t,a,":");t=60*a[1]+a[2]}
60*$2+$3<=t&&60*$4+$5>=t
' <<_INPUT_
a 10:10 10:30
b 12:15 13:15
c 16:54 17:54
_INPUT_
b 12:15 13:15
3)使用函数:
awk -vt="17:15" '
function f(s){split(s,a,":");return(60*a[1]+a[2])}
f($2)<=f(t)&&f($3)>=f(t)
' <<_INPUT_
a 10:10 10:30
b 12:15 13:15
c 16:54 17:54
_INPUT_
c 16:54 17:54