批处理计算时间差的方法总结

   有些时候我们需要计算某些程序或任务执行完毕所耗费的时间,这就需要对时间进行计算,虽然计算时间的代码有N多种,但这里主要是想和大家分享一下用批处理来计算时间差的方法。

   目标:以时、分、秒的形式显示所耗费的时间(不包括日期计算,即不超过24小时)。

   思路:获取开始时间和结束时间,然后计算时间差。

   方法:①退位加减法;②总数加减法

   难点:①如何获取时、分、秒;②如何避开小数点和08、09

   技巧:①用for变量循环法取数;②用变量扩展法取数;③用if判断0开头的数字;④用set /a 去掉0开头的数字


一、获取时间的方法:

   用time变量即可轻松获取任意时点的时间,如

@echo off
set a=%time%
echo.
echo 开始时间:%a%
ping -n 4 127.0.0.1
set b=%time%
echo.
echo 结束时间:%b%
echo.
pause

二、获取时、分、秒的方法:

   通过time变量获取的时间格式是 hour:minite:second,如 20:02:09.07

1、for变量循环截取法

@echo off
set a=%time%
for /f "tokens=1-3 delims=:" %%i in ('echo %a%') do (
  set h1=%%i
  set m1=%%j
  set s1=%%k
)
echo 当前时间是:%h1%时%m1%分%s1%秒
pause

   以上脚本执行的结果是这样的形式:20时02分09.07秒,可见,秒的数是带有小数点的,在后面如果用set /a 命令去计算就会出错,这时也可以再用一次for命令去取小数点的前两位,但这样脚本会显得很累赘,因此我们可以用更简洁的变量扩展法来取数。

   2、变量扩展偏移截取法

   批处理里有变量扩展的命令可用于截取变量中指定位置的字符。

   截取功能统一语法格式为:%a:~[m[,n]]%

   方括号表示可选,%为变量标识符,a为变量名,冒号用于分隔变量名和说明部分,波浪号~可理解为“偏移”,m为偏移量(缺省为0),n为截取长度(缺省为全部)。
   例如 set var=%a:~1,2% 表示把变量a的值从第2位(偏移量1)开始,把2个字符赋予给变量var。

   那么,我们获取时、分、秒数值的脚本如下:

@echo off
set a=%time%
set h1=%a:~0,2%
set m1=%a:~3,2%
set s1=%a:~6,2%
echo 当前时间是:%h1%时%m1%分%s1%秒
pause

   以上脚本执行的结果是这样的形式:20时02分09秒,这时,秒的数值已经没有小数点了,但分和秒的数值高位都是以0开头,如果用set /a 命令去计算还是会出错,为此我们可以再用一次截取命令去判断这个位置的数值是否是0。脚本如下:

if "%m1:~0,1%"=="0" set m1=%m1:~1,1%
if "%s1:~0,1%"=="0" set s1=%s1:~1,1%

   其实我们可以在窃取变量的时候直接用set /a 命令来获取数值,这样更省事,对于以0开头的数字,我们在百位添加一个1给它,然后再减去100即可。脚本如下:

@echo off
set a=%time%
set /a h1=%a:~0,2%
set /a m1=1%a:~3,2%-100
set /a s1=1%a:~6,2%-100
echo 当前时间是:%h1%时%m1%分%s1%秒
pause

   以上脚本执行的结果是这样的形式:20时2分9秒,这样,时、分、秒上的数字就可以直接参与计算了,用同样的方法我们可以获取结束时间:%h2%时%m2%分%s2%秒。


三、计算时间差的方法

   1、退位加减法

   所谓退位加减法就是以分、秒60进制,小时24进制,当被减数不够用时从高位借1来进行计算的方法。这种计算方法与我们用笔来算的方法相同,脚本代码如下:

:: 计算秒数
if %s2% lss %s1% (
set /a m2=%m2%-1
set /a s2=%s2%+60
)
set /a s=%s2%-%s1%
:: 计算分钟数
if %m2% lss %m1% (
set /a h2=%h2%-1
set /a m2=%m2%+60
)
set /a m=%m2%-%m1%
:: 计算小时数
if %h2% lss %h1% (
set /a h2=%h2%+24
)
set /a h=%h2%-%h1%
echo.
echo 耗时是:%h%小时%m%分%s%秒
pause

   2、总数加减法

   所谓总数加减法就是先分别计算开始时间和结束时间的总秒数,然后计算两者相差的秒数,再把相差的秒数换算为时、分、秒的形式。脚本代码如下:

if %h2% LSS %h1% set /a h2=%h2%+24
set /a ts1=%h1%*3600+%m1%*60+%s1%
set /a ts2=%h2%*3600+%m2%*60+%s2%
set /a ts=%ts2%-%ts1%
set /a h=%ts%/3600
set /a m=(%ts%-%h%*3600)/60
set /a s=%ts%%%60
echo 耗时是:%h%小时%m%分%s%秒
pause

四、实例

   下面给出两种计算时间差的完整例子,以供参考:


   方法一:退位加减法

@echo off
set time_begin=%time:~0,-3%
echo 开始时间:%time_begin%
for /f "tokens=1,2,3 delims=:" %%i in ("%time_begin%") do (
set /a hour_b=%%i
set /a munite_b=1%%j-100
set /a second_b=1%%k-100
)
ping -n 4 127.0.0.1
set time_end=%time:~0,-3%
echo 结束时间是:%time_end%
for /f "tokens=1,2,3 delims=:" %%i in ("%time_end%") do (
set /a hour_e=%%i
set /a munite_e=1%%j-100
set /a second_e=1%%k-100
)
call :time_lapse
echo.
echo 耗时%hour_%小时%munite_%分%second_%秒
pause >nul
exit
:time_lapse
:: 一定要按照 秒=>分钟=>小时 的顺序操作
:: 计算秒数
if %second_e% lss %second_b% (
set /a munite_e=%munite_e%-1
set /a second_e=%second_e%+60
)
set /a second_=%second_e%-%second_b%
:: 计算分钟数
if %munite_e% lss %munite_b% (
set /a hour_e=%hour_e%-1
set /a munite_e=%munite_e%+60
)
set /a munite_=%munite_e%-%munite_b%
:: 计算小时数
if %hour_e% lss %hour_b% (
set /a hour_e=%hour_e%+24
)
set /a hour_=%hour_e%-%hour_b%
goto :eof

   方法二:总数加减法

@echo off
set a=%time%
echo.
echo 开始时间:%a%
ping -n 4 127.0.0.1
set b=%time%
echo.
echo 结束时间:%b%
echo.
set /a h1=%a:~0,2%
set /a m1=1%a:~3,2%-100
set /a s1=1%a:~6,2%-100
set /a h2=%b:~0,2%
set /a m2=1%b:~3,2%-100
set /a s2=1%b:~6,2%-100
if %h2% LSS %h1% set /a h2=%h2%+24
set /a ts1=%h1%*3600+%m1%*60+%s1%
set /a ts2=%h2%*3600+%m2%*60+%s2%
set /a ts=%ts2%-%ts1%
set /a h=%ts%/3600
set /a m=(%ts%-%h%*3600)/60
set /a s=%ts%%%60
echo 耗时%h%小时%m%分%s%秒
pause >nul
exit


你可能感兴趣的:(批处理计算时间差)