中国DOS联盟

-- 联合DOS 推动DOS 发展DOS --

联盟域名:www.cn-dos.net 论坛域名:www.cn-dos.net/forum
DOS,代表着自由开放与发展,我们努力起来,学习FreeDOS和Linux的自由开放与GNU精神,共同创造和发展美好的自由与GNU GPL世界吧!

中国DOS联盟论坛
现在时间是 2026-07-01 04:46
中国DOS联盟论坛 » DOS批处理 & 脚本技术(批处理室) » 批处理中如何准确计算时间差? 查看 987 回复 8
楼 主 批处理中如何准确计算时间差? 发表于 2008-10-27 10:31 ·  中国 北京 鹏博士长城宽带
银牌会员
★★★★
[b]看你妹啊[/b]
积分 1,488
发帖 1,357
注册 2006-05-20 12:00
20年会员
UID 55770
状态 离线
我下面的代码是要判断TEST.LOG 多长时间没有更新

计算时间差的部份不知道如何实现。

@echo off

set M=3

set /a SM=0
set /a SH=0

set /a ft=0

set /a TC=0

SET /A LM=0

echo 当前系统时间:%time%
set /a SM=%time:~3,2%

for /f "delims=" %%i in ('dir /a-d /b test.log') do set FT=%%~ti
echo LOG文件最后修改时间: %ft%

SET /A LM=%ft:~-2%

set /a TC=%SM%-%LM%

ECHO LOG文件已经%TC%分钟没有更新了。


pause

有问题请发论坛或者自行搜索,再短消息问我的统统是SB
2 发表于 2008-10-27 10:33 ·  中国 北京 鹏博士长城宽带
银牌会员
★★★★
[b]看你妹啊[/b]
积分 1,488
发帖 1,357
注册 2006-05-20 12:00
20年会员
UID 55770
状态 离线
直接用set /a 计算时间是会有BUG的

例如:

当前系统时间:19:03:51.98
LOG文件最后修改时间: 2008-10-24 16:51
LOG文件已经-48分钟没有更新了。

有问题请发论坛或者自行搜索,再短消息问我的统统是SB
3 发表于 2008-10-27 13:14 ·  中国 北京 鹏博士长城宽带
银牌会员
★★★★
[b]看你妹啊[/b]
积分 1,488
发帖 1,357
注册 2006-05-20 12:00
20年会员
UID 55770
状态 离线
很难么,怎么都没人理我这贴

有问题请发论坛或者自行搜索,再短消息问我的统统是SB
4 发表于 2008-10-27 17:26 ·  中国 北京 鹏博士长城宽带
银牌会员
★★★★
[b]看你妹啊[/b]
积分 1,488
发帖 1,357
注册 2006-05-20 12:00
20年会员
UID 55770
状态 离线
。。。。。。。


有问题请发论坛或者自行搜索,再短消息问我的统统是SB
5 发表于 2008-10-27 17:30 ·  中国 北京 鹏博士长城宽带
银牌会员
★★★★
[b]看你妹啊[/b]
积分 1,488
发帖 1,357
注册 2006-05-20 12:00
20年会员
UID 55770
状态 离线
如果说算时间差很难,可以换个方法,在处理中判断test.log文件是不是已经超过一定不更新,比如,判断test.log是不是已经超过5分钟没有更新。

有问题请发论坛或者自行搜索,再短消息问我的统统是SB
6 发表于 2008-10-28 10:38 ·  中国 北京 鹏博士长城宽带
银牌会员
★★★★
[b]看你妹啊[/b]
积分 1,488
发帖 1,357
注册 2006-05-20 12:00
20年会员
UID 55770
状态 离线
..........

有问题请发论坛或者自行搜索,再短消息问我的统统是SB
7 发表于 2008-10-28 16:33 ·  中国 北京 鹏博士长城宽带
银牌会员
★★★★
[b]看你妹啊[/b]
积分 1,488
发帖 1,357
注册 2006-05-20 12:00
20年会员
UID 55770
状态 离线
为嘛没人注意

有问题请发论坛或者自行搜索,再短消息问我的统统是SB
8 发表于 2008-10-28 20:56 ·  中国 浙江 温州 电信
初级用户
★★
积分 158
发帖 89
注册 2007-04-25 08:06
19年会员
UID 86402
性别 男
状态 离线
我来回一下,我是没看明白。哈哈。
9 发表于 2008-10-28 21:05 ·  中国 浙江 温州 电信
初级用户
★★
积分 158
发帖 89
注册 2007-04-25 08:06
19年会员
UID 86402
性别 男
状态 离线
我在我的F盘创建一个test.log,这句怎么没有执行成功。
for /f "delims=" %%i in ('dir /a-d /b f:\test.log') do set FT=%%~ti
echo LOG文件最后修改时间: %ft%
set 赋值的是空值
最后ECHO显示空值,???没看明白
论坛跳转: