OK. Você pode converter para o horário da Epoch para comparar:
#!/bin/bash
from=$(date -d "$(echo "$1" | awk 'BEGIN { FS = "[/:]"; } { print $1" "$2" "$3" "$4":"$5":"$6 }')" +%s)
to=$(date -d "$(echo "$2" | awk 'BEGIN { FS = "[/:]"; } { print $1" "$2" "$3" "$4":"$5":"$6 }')" +%s)
while read line
do
date=$(echo $line | awk '{ print substr($4, 2, length($4)-1) }' | awk 'BEGIN { FS = "[/:]"; } { print $1" "$2" "$3" "$4":"$5":"$6 }')
date=$(date -d "$date" +%s)
[[ $date -ge $from && $date -le $to ]] && echo $line
done < $3
e chame com algo parecido com isto:
./log_filtering.sh 30/Jul/2011:15:55:44 02/Aug/2011:01:00:00 access_log
Estou tentando escrever em uma linha.
Fazendo com awk
:
#!/bin/awk -f
function toEpoch(t, a) {
split(t, a, "[/:]")
split("Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec", monthname, " ")
for (i=1; i<=12; i++) month[monthname[i]] = i
a[2] = month[a[2]]
return(mktime(a[3]" "a[2]" "a[1]" "a[4]" "a[5]" "a[6]))
}
BEGIN {
start = toEpoch(starttime)
end = toEpoch(endtime)
}
{ date = toEpoch(substr($4, 2, length($4)-1)) }
( date >= start ) && ( date <= end )
e passando os argumentos com -v
:
gawk -f log_filtering.awk -v starttime=30/Jul/2011:04:12:24 -v endtime=02/Aug/2011:04:12:27 access_log