我正在尝试编写一个获取当前日期和时间的cmd脚本,并将其格式化为sqlserver可以将其作为datetime
输入的方式。
到目前为止,我有:
@echo off
for /F "tokens=1-4 delims=/ " %%i in ('date /t') do (
set dow=%%i
set mon=%%j
set day=%%k
set yr=%%l
set mydate=%%j/%%k/%%l
)
打印出10/22/2010
我无法弄清楚如何将时间转化为可用的格式。我尝试使用time /t
,但它只提供小时和分钟,我也需要秒数。
答案 0 :(得分:51)
使用%TIME%
伪变量。
您也可以在上面的脚本中使用%DATE%
。
两者都有相同的限制,因为它们取决于您的语言环境。代码不可移植,您将在其他环境中获得惊喜。但这就是cmd中日期和时间的工作方式。
答案 1 :(得分:14)
替代方法,其中%TIME%的格式为H:MM:SS.FF,H的范围为0 - 23,可用一位数表示(基于this article):
set YYYY=%DATE:~10,4%
set MM=%DATE:~4,2%
set DD=%DATE:~7,2%
set HH=%TIME: =0%
set HH=%HH:~0,2%
set MI=%TIME:~3,2%
set SS=%TIME:~6,2%
set FF=%TIME:~9,2%
set dirName=%YYYY%%MM%%DD%
set fileName=%dirName%\%YYYY%%MM%%DD%_%HH%%MI%%SS%.tmp
echo %fileName%
答案 2 :(得分:7)
以下是我使用蝙蝠脚本的方式:
@echo off
For /f "tokens=2-4 delims=/ " %%a in ("%DATE%") do (
SET YYYY=%%c
SET MM=%%a
SET DD=%%b
)
For /f "tokens=1-4 delims=/:." %%a in ("%TIME%") do (
SET HH24=%%a
SET MI=%%b
SET SS=%%c
SET FF=%%d
)
echo %%DATE%%=%DATE%
echo %%TIME%%=%TIME%
echo %YYYY%-%MM%-%DD%_%HH24%-%MI%-%SS%-%FF%
echo %YYYY%/%MM%/%DD% %HH24%:%MI%:%SS%
echo %MM%/%DD%/%YYYY% %HH24%:%MI%:%SS%
echo YYYY=%YYYY%
echo MM=%MM%
echo DD=%DD%
echo HH24=%HH24%
echo MI=%MI%
echo SS=%SS%
echo FF=%FF%
pause
您现在可以删除所有回声并通过键入以下任何bat文件来使用它:
call SetDateTimeVariables.bat
示例:创建存档目录并存储位置:
@echo off
SETLOCAL
call test2.bat
ENDLOCAL&(
SET ARCHIVE_DIR="archive/%YYYY%%MM%%DD%%HH24%%MI%%SS%"
)
MKDIR "%ARCHIVE_DIR%"
答案 3 :(得分:1)
echo %time:~-5%
http://ss64.com/nt/syntax-substring.html
%time%的最后5个字符始终为seconds dot milliseconds
示例输出:
33.84