有没有办法在Windows命令行上将前一周的第一天和最后一天变为两个变量? 我想使用的日期格式是YYYY-MM-DD。
答案 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有一个参数,请注意它的唯一目的是执行你要求的日期计算:
要将请求的值放入两个变量,您可以执行以下操作:
@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%