我已经安排了备份脚本来转储数据库。如何将日期时间戳添加到文件名中?
我说的是 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
命令来解析由或特定于语言环境的格式分隔的标记/
来更改格式。