Re: нарезать логи

From
Valentin Davydov (2:5020/400)
To
Andrey Zonov
Date
2006-11-22T10:18:30Z
Area
RU.UNIX.BSD
From: Valentin Davydov <val@sqdp.trc-net.co.jp>

>   From: Andrey Zonov <Andrey.Zonov@p28.f830.n5020.z2.fidonet.org>
>   Date: Tue, 21 Nov 2006 21:42:56 +0300
>
> AZ>> Помогите нарезать логи по часам.
> AZ>> формат лога:
> AZ>> 00:00 2006-10-01
> AZ>> <some>
> AZ>> 00:01 2006-10-01
> AZ>> <some>
> AZ>> ...
>
> EG> Если однократно, то легко так:
>
> EG> awk '/^..:.. ....-..-..$/ {hour=$1; sub(/:.*/,"",hour); fname=$2 "-"
> EG> hour;}
> {print>>> fname;}'
>
>Спасибо оно, только вот awk зараза вылетает
>
>[root@dotnet /tmp/1/2006-09]# awk '/^..:.. ....-..-..$/ {hour=$1;
>sub(/:.*/,"",hour); fname=$2 "-" hour;} {print>>fname;}' stat_dvb0.2006-09-01
>awk: 2006-09-01-17 makes too many open files
> input record number 3811, file stat_dvb0.2006-09-01
> source line number 1
>
>а вот гнутый (он же) - бес проблем парсанул 25 метровый файл.

Ну так ты не первый, кто попал на кривизну этого новомодного авка. В принципе,
можно после каждой print>>fname говорить close(), если некоторая потеря 
производительности не критична.

Вал. Дав.

P.S. Редиски, зря испохабили хорошую утилиту.
--- ifmail v.2.15dev5.3
 * Origin: Demos online service (2:5020/400)
SEEN-BY: 50/12 400/814 450/159 1024 461/43 132 640 469/999 4616/3 4625/8
SEEN-BY: 4641/444 5000/76 5000 5006/1 5007/1 5010/70 5011/13 5012/46 5015/28
SEEN-BY: 5019/31 5020/18 175 194 400 545 982 1057 1909 1922 2238 2395 2871
SEEN-BY: 5020/4441 5021/29 5025/3 5026/14 45 5027/12 5030/1080 1957 5034/10 13
SEEN-BY: 5035/3 38 5036/1 5045/7 5049/1 5051/15 5054/1 4 8 9 11 28 35 36 37 45
SEEN-BY: 5054/63 66 67 70 75 84 85 5059/9 5060/88 5061/15 5062/10 5063/3
SEEN-BY: 5064/7 5066/18 5075/5 5076/1 5077/70 5080/1003 5084/9 5085/13 5095/20
SEEN-BY: 5096/18 6001/10
PATH: 5020/400 545 5054/1 37