У меня есть запланированный сценарий резервного копирования, который создает дамп базы данных. Как я могу добавить дату и время к имени файла?
Я говорю о Windows и CMD.
У меня есть запланированный сценарий резервного копирования, который создает дамп базы данных. Как я могу добавить дату и время к имени файла?
Я говорю о Windows и CMD.
Ответы:
В командной строке и командных файлах вы можете использовать %date%
и %time%
для возврата даты и времени соответственно. Дата работает нормально, но возвращаемое значение времени содержит двоеточия, которые недопустимы для использования в именах файлов, но есть способ удалить их.
Используйте что-то вроде:
COPY file.txt file_%time:~0,2%%time:~3,2%%time:~6,2%_%date:~-10,2%%date:~-7,2%%date:~-4,4%.txt
Это создаст имя файла, такое как file_172215_01062009.txt
Обновление: комментарии ниже содержат интересные поводы для этой команды, а также некоторые потенциальные проблемы, которые вы можете избежать.
%DATE%
и %TIME%
с учетом местных особенностей! Это значит, что на европейской машине вы получите DD.MM.YYYY
. Arrgh.
Используйте переменные окружения %DATE%
и / или %TIME
, необязательно заменяя символы, которые не допускаются в именах файлов, с помощью %name:from=to%
( %TIME::=%
удалит все двоеточия).
теория »эхо% дата% 2009-06-01 теория »эхо% время% 16: 30: 41,46 теория »эхо% времени :: =% 163052,17 теория »эхо% времени :: =,% 16,30,58,68 теория »резервное копирование эхо-% дата% -% время :: = -%. zip резервное копирование 2009-06-01-16-31-18,82.zip
set tmp=%tmp:x=y%
и т. Д.
Единственный надежный способ получить соответствующую дату независимо от региональных настроек - это решение от foxidrive @ /programming/11037831/filename-timestamp-in-windows-cmd-batch-script
@echo off
for /f "tokens=2 delims==" %%a in ('wmic OS Get localdatetime /value') do set "dt=%%a"
set "YY=%dt:~2,2%" & set "YYYY=%dt:~0,4%" & set "MM=%dt:~4,2%" & set "DD=%dt:~6,2%"
set "HH=%dt:~8,2%" & set "Min=%dt:~10,2%" & set "Sec=%dt:~12,2%"
set "datestamp=%YYYY%%MM%%DD%" & set "timestamp=%HH%%Min%%Sec%"
set "fullstamp=%YYYY%-%MM%-%DD%_%HH%-%Min%-%Sec%"
echo datestamp: "%datestamp%"
echo timestamp: "%timestamp%"
echo fullstamp: "%fullstamp%"
pause
Используйте переменную% DATE% в имени файла.
Существует также переменная% TIME%, но она содержит символы, которые не допускаются в имени файла.
Вот пример записи строки текста в новый файл, в имени которого у созданного файла есть дата и время.
echo "testfile" >> backup-%DATE%.txt