bat中使用mshta调用vbs语句获取精准计算的日期
大家好,又见面了,我是你们的朋友全栈君。
1.在bat中,获取指定的日期格式是比较麻烦的。因为cmd环境中,日期格式随着系统的时间格式设置而变化,通常系统默认的时间格式是“\’”符号作为连接符。 日期通常用在文件名上,比如日志的文件名。那么日期的格式就只能用“-”符号代替,更改系统日期格式会显得容易被外界因素改变,导致不稳定。当然也可以用bat中的set来进行替换,但这样费代码量。 2.对于计算日期来说,bat是难以准确做到的,也需要堆积代码量才能完成。特别是到了每个月的一号时,无法确定昨天是否是31号还是30号还是28号。那么bat就只能陷入迷茫。
本期将介绍在for中嵌入mshta调用vbs的用法,如何一次实现日期连接符及精准计算日期。 以下是bat中的代码:
@echo off
for /f %%a in ('mshta VBScript:Execute("NewDate=date+(-1):FmtDate=right(year(NewDate),4)&""-""&right(""0""&month(NewDate),2)&""-""&right(""0""&day(NewDate),2):CreateObject(""Scripting.FileSystemObject"").GetStandardStream(1).Write FmtDate:close"^)') do (
set yd=%%a
)
set /p=%yd%
运行结果如下图,返回的日期是昨天,因为今天是17号:
mshta代码段解析:NewDate变量值为减去1天后的日期,再把减去一天的日期传递给FmtDate变量。 FmtDate再把年月日进行处理,补0和“-”符号进行连接,最后输出FmtDate变量给bat中的for。是不是感觉有点绕,那么我们简单拆分来分析下。
NewDate=date+(-1):FmtDate
NewDate的变量为:当日的日期减去1天然后传递给FmtDate。
""0""&month(NewDate),2)&""-""
这里把NewDate变量中的月份保留两位数,如果是只有一位数,比如9月,那么前面就会补一个0,变成09。后面再加连接符“-”,结果就是“09-”。后面的天数代码也是这样,就不重复说了。
Write FmtDate:close"
这个好理解,把FmtDate的结果输出给Bat中的for。
那么mshta调用来轻松解决bat中计算日期的方法就到这里啦。 更多关于bat中的时间处理技巧请关注我博客,后面会继续更新!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/234318.html原文链接:https://javaforall.cn
相关文章
- Shell循环遍历日期「建议收藏」
- js根据起始日期加间隔天数计算出结束日期
- python计算N天之后的日期详解编程语言
- 日期查找:如何在Linux系统中检索文件(linux按日期查找文件)
- 数解析MySQL日期与秒数(mysql日期秒)
- 一起走进Linux时代 改变你的日期方式(datelinux)
- Oracle计算日期对应的星期几(oracle日期周几)
- Oracle日期计算:精准识别时间的函数(oracle日期计算函数)
- 利用Oracle中的星期函数计算日期(oracle星期函数)
- 函数使用Oracle中的日期函数计算日期(oracle中的日期)
- 计算 Oracle 日期间隔:技巧与实践(oracle日期间隔)
- Oracle中将毫秒转换为日期的方法(oracle毫秒转日期)
- MySQL查询如何获取日期的前一天(mysql日期的前一天)
- 解析Oracle计算日期差(oracle 求日期差)
- SQL Server日期计算:加减无忧(sqlserver日期加减)
- 计算日期差:MSSQL中的实现方法(mssql 计算日期差)
- Oracle日期计算几天后的时刻(oracle 几天后日期)
- 基于JQuery的日期联动实现代码