如何在cmd中检索TIME的秒部分?

时间:2010-11-22 17:23:32

标签: batch-file cmd

我正在尝试编写一个获取当前日期和时间的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,但它只提供小时和分钟,我也需要秒数。

4 个答案:

答案 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