forum.wfido.ru  

Вернуться   forum.wfido.ru > Архив Калужских эх > ARC2.KLG.SOFTHARD

ARC2.KLG.SOFTHARD Архив Калужской эхи о софте и железе

 
 
Опции темы Опции просмотра
  #1  
Старый 09.10.2018, 15:34
Bogdan Spasennikov
Guest
 
Сообщений: n/a
По умолчанию Скрипт / Помощь в написании

Bogdan Spasennikov написал(а) к All в Jan 07 03:59:12 по местному времени:

Доброе время суток, All !

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

200612_29_00mainchat.log
200612_29_01mainchat.log
200612_29_02mainchat.log
200612_29_03mainchat.log

Т.е. имя в формате yyyymm_dd_hhmainchat.log, где hh - час (00..23). Требуется из пакетного файла собрать все эти файлы по-порядку в единый mainchat.log (за один день). Т.к. кроме языка командного интерпретатора cmd.exe я больше ничем не владею (имеются ввиду всякие там VBScript и прочие), то набросал следующее:

for /l %%n in (0,1,9) do (
FOR /F "usebackq tokens=1-3 delims=." %%i IN (`echo %date%`) DO type "%%k%%j_%%i_0%%nmainchat.log" >> "mainchat.log"
)

for /l %%n in (10,1,23) do (
FOR /F "usebackq tokens=1-3 delims=." %%i IN (`echo %date%`) DO type "%%k%%j_%%i_%%nmainchat.log" >> "mainchat.log"
)

В первом цикле, как видно, "пробегаются" часы от 00 до 09, во втором от 10 до 23, разбиение на два цикла сделано потому, что я не придумал как по-другому подставить лидирующий ноль в имени файла для часов < 10. Все это запускается в планировщике в 23:59, соответственно в %date% мы имеем текущую дату и mainchat.log собирается за текущий день 00:00-23:59, но есть одно но. Иногда система бывает загружена и bat'ник запускается не в 23:59, а с небольшим опозданием, например в 00:00:01, тогда mainchat.log не собирается из кусков ... т.к. за эту дату логи по часам еще не писались. Как бы дописать его, чтобы логи собирались не за текущую дату, а за предыдущую?

С уважением, Bogdan !

( ) E-Mail: twilight_zone(at)mail.ru, ICQ# 977-628
--- GoldED+/W32-MSVC 1.1.5-20060917 (WinNT 5.1.2600-SP2 iP-IV)
  #2  
Старый 09.10.2018, 15:34
Pavel Povarov
Guest
 
Сообщений: n/a
По умолчанию Скpипт / Помощь в написании

Pavel Povarov написал(а) к Bogdan Spasennikov в Jan 07 09:53:04 по местному времени:

Добpое вpемя сyток, Bogdan!

Втоpник 30 Янваpя 2007 03:59, Bogdan Spasennikov -> All:

[ skiped ]
BS> for /l %%n in (0,1,9) do (
BS> FOR /F "usebackq tokens=1-3 delims=." %%i IN (`echo %date%`) DO
BS> type "%%k%%j_%%i_0%%nmainchat.log" >> "mainchat.log"
BS> )
BS>
BS> for /l %%n in (10,1,23) do (
BS> FOR /F "usebackq tokens=1-3 delims=." %%i IN (`echo %date%`) DO
BS> type "%%k%%j_%%i_%%nmainchat.log" >> "mainchat.log"
BS> )
[ skiped ]

А ты можешь датy не каждый pаз в цикле считывать, а в начале скpипта записать в какyю-нибyдь пеpеменнyю?
И потом yже датy из этой пеpеменной использовать.
(Может я конечно глyпость сказал, т.к. в cmd-скpиптах не силён. Но выход мне видится такой.)

С yважением, Павел.

... Мы тyт водкy пьянствyем и голых женщин pаздеваем ...
--- GoldED+/W32 1.1.4.7
  #3  
Старый 09.10.2018, 15:34
Bogdan Spasennikov
Guest
 
Сообщений: n/a
По умолчанию Скpипт / Помощь в написании

Bogdan Spasennikov написал(а) к Pavel Povarov в Jan 07 13:18:18 по местному времени:

Доброе время суток, Pavel !

Помнится 30 Янв 07 09:53, Pavel Povarov писал к Bogdan Spasennikov:

PP> А ты можешь датy не каждый pаз в цикле считывать, а в начале скpипта
PP> записать в какyю-нибyдь пеpеменнyю? И потом yже датy из этой
PP> пеpеменной использовать. (Может я конечно глyпость сказал, т.к. в
PP> cmd-скpиптах не силён. Но выход мне видится такой.)
Вчерашнюю дату средствами только пакетных файлов не могу, могу только сегодняшнюю, которая из %date% берется. Вообщем так или иначе вышел из ситуации, правда как-то коряво получилось (если все это переписать на VBScript будет смотреться гораздо изящнее, сейчас этим времени заниматься нет), но зато работает:

Так мы получаем вчерашнюю дату в %yesterday%:

FOR /F "tokens=*" %%A IN ('cscript D:\ftn_2\yesterday.vbs //nologo') DO set %%A

Дальше используем ее в этих двух циклах:

for /l %%n in (0,1,9) do (
FOR /F "tokens=1-3 delims=." %%i IN ("%yesterday%") DO type "%%k%%j_%%i_0%%nmainchat.log" >> "mainchat.log"
)

for /l %%n in (10,1,23) do (
FOR /F "tokens=1-3 delims=." %%i IN ("%yesterday%") DO type "%%k%%j_%%i_%%nmainchat.log" >> "mainchat.log"
)

А вот и текст скрипта для получения вчерашней даты (результатом его работы является строка вида 'yesterday=dd.mm.yyyy', соответственно когда в вышеприведенном цикле переменная yesterday при выполнении set %%A принимает это значение):

' Yesterday.vbs, Version 1.01 for Windows Script Нost 2.00
' Display today's and yesterday's date in two formats
'
' Written by Rob van der Woude
' http://www.robvanderwoude.com

' Specify header
strНead = "Format: YYYYMMDD (DD/MM/YYYY)" & Chr(13) & Chr(10) & _
"==================================" & Chr(13) & Chr(10)

' Get current year
strYear = DatePart("yyyy",Date)

' Get current month, add leading zero if necessary
If DatePart("m",Date) < 10 Then
strMonth = 0 & DatePart("m",Date)
Else
strMonth = DatePart("m",Date)
End If

' Get current day, add leading zero if necessary
If DatePart("d",Date) < 10 Then
strDay = 0 & DatePart("d",Date)
Else
strDay = DatePart("d",Date)
End If

' Format output for today
strToday = "Today: " & strYear & strMonth & strDay & " (" & _
strDay & "/" & strMonth & "/" & strYear & ")" & Chr(13) & Chr(10)

' Calculate yesterday's date
dtmYesterday = DateAdd("d",-1,Date)

' Get yesterday's year
strYear = DatePart("yyyy",dtmYesterday)

' Get yesterday's month, add leading zero if necessary
If DatePart("m",dtmYesterday) < 10 Then
strMonth = 0 & DatePart("m",dtmYesterday)
Else
strMonth = DatePart("m",dtmYesterday)
End If

' Get yesterday's day, add leading zero if necessary
If DatePart("d",dtmYesterday) < 10 Then
strDay = 0 & DatePart("d",dtmYesterday)
Else
strDay = DatePart("d",dtmYesterday)
End If

' Format output for yesterday
'strYest = "Yesterday: " & strYear & strMonth & strDay & " (" & _
' strDay & "/" & strMonth & "/" & strYear & ")"

strYest = "yesterday=" & strDay & "." & strMonth & "." & strYear

' Display the result
' Wscript.Echo( strНead & strToday & strYest )

Wscript.Echo( strYest )

С уважением, Bogdan !

( ) E-Mail: twilight_zone(at)mail.ru, ICQ# 977-628
--- GoldED+/W32-MSVC 1.1.5-20060917 (WinNT 5.1.2600-SP2 iP-IV)
 


Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Выкл.
[IMG] код Выкл.
HTML код Выкл.

Быстрый переход


Текущее время: 01:27. Часовой пояс GMT +4.


Powered by vBulletin® Version 3.8.7
Copyright ©2000 - 2024, vBulletin Solutions, Inc. Перевод: zCarot