文件名中的当前日期

文件名中的当前日期

我已经安排了备份脚本来转储数据库。如何将日期时间戳添加到文件名中?

我说的是 Windows 和 CMD。

答案1

在命令提示符和批处理文件中,您可以使用%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

更新:下面的评论对此命令进行了有趣的阐述,并指出了一些您可以避免的潜在问题。

答案2

使用%DATE%和/或%TIME环境变量,可选择替换文件名中不允许的字符,使用%name:from=to%%TIME::=%将删除所有冒号)。

理论 » echo %date%
2009-06-01

理论 » echo %time%
16:30:41,46

理论 » echo %time::=%
163052,17

理论 » echo %time::=,%
16,30,58,68

理论 » echo backup-%date%-%time::=-%.zip
备份-2009-06-01-16-31-18,82.zip

答案3

无论区域设置如何,获取适当日期的唯一可靠方法是来自 foxidrive @ 的解决方案https://stackoverflow.com/questions/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

答案4

使用%date%%time%变量,您可以使用For /f命令来解析由或特定于语言环境的格式分隔的标记/来更改格式。

相关内容