在Windows命令行上获取前一周的第一天和最后一天

时间:2015-03-04 16:32:41

标签: batch-file command-line windows-console

有没有办法在Windows命令行上将前一周的第一天和最后一天变为两个变量? 我想使用的日期格式是YYYY-MM-DD。

2 个答案:

答案 0 :(得分:1)

如果您可以使用vbscript,则可以尝试以下操作:

创建文件 vbdate.vbs

function YMD(d)
    YMD = Year(d) & _
               "-" & Right("00" & Month(d),2) & _
               "-" & Right("00" & Day(d),2) 
end function

set oArgs=WScript.Arguments
' Assuming first day of the week is Monday:
WScript.echo YMD(DateAdd("d", -((Weekday(Now()) + 7 - 2) Mod 7) + oArgs(0), Now()))

如果您希望星期日成为一周的第一天,请将最后一行替换为:

WScript.echo YMD(DateAdd("d", -((Weekday(Now()) + 7 - 1) Mod 7) + oArgs(0), Now()))

这个vbscript有一个参数,请注意它的唯一目的是执行你要求的日期计算:

  • 6将为您提供当周的最后一天
  • 0将为您提供当周的第一天
  • -1将为您提供上一周的最后一天
  • -7将为您提供上周的第一天

要将请求的值放入两个变量,您可以执行以下操作:

@echo off

FOR /F "usebackq tokens=*" %%r in (`CSCRIPT //Nologo "vbdate.vbs" -7`) DO SET RESULT1=%%r
FOR /F "usebackq tokens=*" %%s in (`CSCRIPT //Nologo "vbdate.vbs" -1`) DO SET RESULT2=%%s

REM First day of previous week
ECHO %RESULT1%
REM Last day of previous week
ECHO %RESULT2%

答案 1 :(得分:0)

我不确定你如何定义你的星期,但我会假设星期从星期日开始。

批量进行日期/时间计算是一件痛苦的事。但是如果你使用我的getTimestamp.bat utility - 一个可用于执行几乎任何日期/时间计算和格式化任务的混合JScript /批处理脚本,问题就可以轻松解决。该实用程序是纯脚本,可​​以在XP之后的任何Windows机器上本机运行。

@echo off
setlocal
call getTimestamp /f "{w}" /r dayOfWeekNum
call getTimestamp /od "-%dayOfWeekNum%-7" /f "{yyyy}-{mm}-{dd}" /r beginDate
call getTimestamp /od "-%dayOfWeekNum%-1" /f "{yyyy}-{mm}-{dd}" /r endDate
echo Last week begin date = %beginDate%
echo Last week end date   = %endDate%

修改

以上内容可以很容易地概括为支持任何一天作为一周的开始。此外,如果脚本在从一周过渡到下一周的午夜之前的一瞬间运行,则脚本可能会给出错误的结果。我通过只获取当前日期一次,然后执行相对于该日期的所有计算来解决以下问题。

下面的脚本将星期一指定为一周的开始。

@echo off
setlocal
set "weekStart=1"  %= 0=Sunday, 1=Monday, 6=Saturday =%
call getTimestamp /f "{ums}" /r today
call getTimestamp /d %today% /f "{w}" /r dayOfWeekNum
set /a "dayOfWeekNum=(7+dayOfWeekNum-weekStart)%%7"
call getTimestamp /d %today% /od "-%dayOfWeekNum%-7" /f "{wkd} {yyyy}-{mm}-{dd}" /r beginDate
call getTimestamp /d %today% /od "-%dayOfWeekNum%-1" /f "{wkd} {yyyy}-{mm}-{dd}" /r endDate
echo Last week begin date = %beginDate%
echo Last week end date   = %endDate%