Компьютерный форум OSzone.net  

Компьютерный форум OSzone.net (http://forum.oszone.net/index.php)
-   Скриптовые языки администрирования Windows (http://forum.oszone.net/forumdisplay.php?f=102)
-   -   [решено] Обработка логов (http://forum.oszone.net/showthread.php?t=218568)

hvorost 21-10-2011 15:36 1778695

Обработка логов
 
Добрый день!
Помогите написать батник который будет обрабатывать логи программы.
Имеется программа которая ежедневно создает новые лог файл In 21.10.2011.log и Out 21.10.2011.log
Нужно написать батник который будет искать в логе с сегодняшней датой слово error или not connect
и если нашел всю эту строку копировать в новый файл sendmail с добавлением перед копируемой строкой еще адрес support@

Foreigner 21-10-2011 16:45 1778760

hvorost,
Код:

@echo off
setlocal

for /f %%i in ('date /t') do set "file=%%i.log"
for %%i in (in out) do (

      for /f "tokens=*" %%j in ('findstr /i "\<error\>" "%%i %file%"') do 1>>sendmail echo support@%%j
      for /f "tokens=*" %%j in ('findstr /i "\<not.connect\>" "%%i %file%"') do 1>>sendmail echo support@%%j

)

Попробуй. Если нет спецсимволоа, то все должно работать

hvorost 23-10-2011 11:47 1779782

А как еще в этот батник добавить, чтобы он создавал файл sendmail если ходя бы один файл не найден?

Foreigner 23-10-2011 12:03 1779795

Цитата:

Цитата hvorost
А как еще в этот батник добавить, чтобы он создавал файл sendmail если ходя бы один файл не найден? »

Код:

@echo off
setlocal

for /f %%i in ('date /t') do set "file=%%i.log"
for %%i in (in out) do (

      if not exist "%%i %file%" 1>>sendmail echo "%%i %file%" not found

      for /f "tokens=*" %%j in ('findstr /i "\<error\>" "%%i %file%"') do 1>>sendmail echo support@%%j
      for /f "tokens=*" %%j in ('findstr /i "\<not.connect\>" "%%i %file%"') do 1>>sendmail echo support@%%j

)


Imodem174 26-10-2011 12:57 1782041

Спасибо за отличный пример, у меня схожая проблема, но я так и не смог разобраться в выложенном батнике...проблема следующая, есть программа, каждый час она создает новый лог с именем 88.151.108.95_4567-ASUSK-12011102613.log, где 13 в конце-это час, необходимо в логе искать данные, начинающиеся после символа '>' и заканчивающиеся перед символом '<', в случае, если данные начинаются со слова 'ASUSK', пропускать их, а если начинаются с какой-либо цифры, копировать их в файл с таким же именем, как и лог, но с разрешением dat. Заранее благодарен! eMail andry-i@mail.ru

Foreigner 26-10-2011 15:53 1782208

Imodem174,
Не совсем понял на счет времени в названии лога (в твоем примере 13). Для чего они? Нужно как-то обрабатывать исходя из времени? В остальном, попробуй такой вариант:
Код:

@echo off

for %%i in (*.log) do call:1 "%%i"
goto:eof

:1
for /f "tokens=2 delims=<>" %%i in ('findstr ">[0-9].*<" %1') do 1>>"%~n1.dat" echo %%i


Imodem174 26-10-2011 17:12 1782266

Спасибо, сейчас попробую...каждый час программа создает новый файл лога, таким образом лог, созданный с 13 до 14 часов дня называется 88.151.108.95_4567-ASUSK-12011102613.log, лог с 14 до 15 - 88.151.108.95_4567-ASUSK-12011102614.log, с 18 до 19 - 88.151.108.95_4567-ASUSK-12011102618.log. В результате работы батника в папке с логами должны появиться файлы с расширением dat, соответствующие файлам логам и сформированные по вышеизложенным правилам.

Imodem174 26-10-2011 18:58 1782342

батник работает, но только не циклично, то есть он действительно создает файл с расширением dat и копирует в него данные, но только первый пакет, то есть данные которые находятся в начале файла между > и < следующие он уже не копирует(...привожу пример

данные в логе...
<20111026060113.562>95,29787
95,29787
95,29787
95,29787
95,29787
86,23417
86,23417
86,23417
86,23417
<20111026060126.375>ASUSK-1
PmpStat1 = A000
PmpStat2 = 4000
FCFault1 = 00
FCFault2 = 00
FCAlarm = 00
FCLimit = 00
Runtime = 3155.0min
MSW = 1F37
<20111026060158.218>100,32037
100,32037
100,32037
100,32037
100,32037
99,30582
99,30582
99,30582
<20111026065709.203>28,18000
28,18000
13,19350
13,19350
13,19350
13,19350
<20111026065722.046>ASUSK-1
PmpStat2 = 4000
FCFault1 = 00
FCFault2 = 00
FCAlarm = 00
FCLimit = 00
Runtime = 3211.0min
MSW = 1F37
<20111026065753.437>43,20022
43,20022
43,20022

в итоге должен получиться файл с расширением dat с названием от лог файла и следующим содержанием...
95,29787
95,29787
95,29787
95,29787
95,29787
86,23417
86,23417
86,23417
86,23417
100,32037
100,32037
100,32037
100,32037
100,32037
99,30582
99,30582
99,30582
28,18000
28,18000
13,19350
13,19350
13,19350
13,19350
43,20022
43,20022
43,20022

Foreigner 26-10-2011 19:41 1782372

Imodem174, Я просто думал, что "> данные <" это одна строка в логе. Может проще найти все строки вида 99,99999?
Код:

@echo off

for %%i in (*.log) do (

    for /f "tokens=1-3 delims=<>," %%j in ('findstr "[0-9],[0-9]" "%%i"') do call:1 %%i %%j %%k %%l

)
goto:eof

:1
::echo %1 %2 %3 %4

if "%4"=="" (echo 1>>%~n1.dat %2,%3) else (echo 1>>%~n1.dat %3,%4)


Imodem174 27-10-2011 13:35 1782857

Спасибо, на этот раз все работает, только почему-то он пропускает и слова типа ASUSK-1 и UNKNOWNOK...но это как выяснилось на программу, для которой нужны выходные файлы dat не влияет, поэтому можно сказать, что результат положительный!Еще раз спасибо. Хочется так же научиться писать батники и разбираться в этом языке, може посоветуете литературу?


Время: 20:54.

Время: 20:54.
© OSzone.net 2001-