[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

[数值计算] 求助计算花费时间的批处理为什么变量一直显示为0?

我做了一个基准测试批处理,测试bat文件解释器的性能,但是最后输出花费的时间,总是输出0,代码如下:
  1. @echo off
  2. title 基准测试
  3. color 0a
  4. set /p number=Type_RunNumber:
  5. set t1=%time%
  6. set a=0
  7. :run
  8. set /a a=a+1
  9. if %a% gtr %number%=goto end_run
  10. goto run
  11. :end_run
  12. set t2=%time%
  13. set /a t3=t2-t1
  14. title 加法%a%次
  15. echo Run_Number:%number%  Run_Time:%t3%
  16. pause
复制代码
最后那个echo中有一个变量:%t3%,这个变量的值理论上应该就是运行花费的时间,这个值是怎么求出来的可以在代码里往前找一找,前面的%time%不是我自己定义的变量,在批处理中它的值就是当前的时间,现在的问题是,显示的运行时间永远是0,哪怕肉眼观察的运行时间有好几秒,求助

http://bbs.bathome.net/thread-63632-1-1.html
运行你的程序前,运行一下GetSec.exe,得到一个秒数,运行你的程序后再运行一下GetSec.exe,得到第二个秒数,两个秒数相差,就是你程序运行的时间。
  1. @echo off&cd /d "%~dp0"
  2. for /f %%s in ('GetSec.exe') do set Sec1=%%s
  3. ping 127.1 -n 6
  4. for /f %%s in ('GetSec.exe') do set Sec2=%%s
  5. set /a s=%Sec2%-%Sec1%
  6. echo.&echo;运行时间: %s% 秒
  7. echo.&pause
复制代码

TOP

回复 25# LTSC1809


    咱们这个论坛里面懂批处理的基本上都是自学的
我帮忙写的代码不需要付钱。如果一定要给,请在微信群或QQ群发给大家吧。
【微信公众号、微信群、QQ群】http://bbs.bathome.net/thread-3473-1-1.html
【支持批处理之家,加入VIP会员!】http://bbs.bathome.net/thread-67716-1-1.html

TOP

  1. @echo off
  2. for /f "tokens=1-3delims=:." %%i in ("%time%") do set /a t1=%%i*3600+ (10%%j)%%100*60+10%%k%%100
  3. for /l %%i in (1,1,30000) do ver>nul
  4. for /f "tokens=1-3delims=:." %%i in ("%time%") do set /a t2=%%i*3600+ (10%%j)%%100*60+10%%k%%100
  5. set /at=t2 - t1
  6. echo;%t%
  7. pause
复制代码
1

评分人数

    • LTSC1809: 感谢回复 技术+1 技术+1 技术+1 技术+1 技术 ...技术 + 1

TOP

回复 27# LTSC1809


    你试了那两个参数就知道,它是分别提取时,分为数字,可以用来计算的
1

评分人数

TOP

回复 26# mzzyb 谢谢回复,但是time变量不是纯数字,有冒号点号,怎么运算啊

TOP

本帖最后由 mzzyb 于 2023-4-26 17:40 编辑

你可以直接提取当前系统的时间配合if函数判断,运算一下,就可以了,
提取时    %time:~0,2%
提取分    %time:~3,2%
下面是个简单的例子,希望帮到你
  1. set /p h=请输小时:
  2. set /p m=请输分钟:
  3. set /a nowh=%time:~0,2%
  4. set /a nowm=%time:~3,2%
  5. echo %nowh%
  6. echo %nowm%
  7. if %nowh% equ %h% (
  8. set /a "t=(%m%-%nowm%)*60"
  9. shutdown /s /t %t%
  10. ) else if %nowm% GTR %m% (
  11. set /a "t=(%h%-%nowh%-1)*3600+(60-%nowm%+%m%)*60"
  12. shutdown /s /t %t%
  13. ) else (set /a "t=(%h%-%nowh%)*3600+(%m%-%nowm%)*60"
  14. shutdown /s /t %t%
  15. )
复制代码

TOP

自学的批处理果然还是不太好,今后望大家多多指教

TOP

回复 22# Batcher 改好了,请参阅
  1. @echo off
  2. title 基准测试
  3. color 0a
  4. set /p number=Type_RunNumber:
  5. set t1=%time%
  6. set a=0
  7. :run
  8. set /a a=a+1
  9. if %a% gtr %number%=goto end_run
  10. goto run
  11. :end_run
  12. set t2=%time%
  13. for /f "delims=:.tokens=1" %%i in ("%t1%") do set t1h=%%i
  14. for /f "delims=:.tokens=2" %%i in ("%t1%") do set t1m=%%i
  15. for /f "delims=:.tokens=3" %%i in ("%t1%") do set t1s=%%i
  16. for /f "delims=:.tokens=4" %%i in ("%t1%") do set t1ms=%%i
  17. for /f "delims=:.tokens=1" %%i in ("%t2%") do set t2h=%%i
  18. for /f "delims=:.tokens=2" %%i in ("%t2%") do set t2m=%%i
  19. for /f "delims=:.tokens=3" %%i in ("%t2%") do set t2s=%%i
  20. for /f "delims=:.tokens=4" %%i in ("%t2%") do set t2ms=%%i
  21. set /a t3h=t2h-t1h
  22. set /a t3m=t2m-t1m
  23. set /a t3s=t2s-t1s
  24. set /a t3ms=t2ms-t1ms
  25. title 加法%a%次
  26. echo Run_Number:%number%  Run_Time:%t3h%:%t3m%:%t3s%.%t3ms%
  27. pause
复制代码

TOP

回复 22# Batcher 给变量加个引号就好了对吗,还有把变量名改了就能解决显示时间是负数的问题?

TOP

回复 17# LTSC1809


因为for /f只能处理文件

你看到哪个教程上面这么说的?

可以考虑换个教程,例如:
http://bbs.bathome.net/thread-31727-1-1.html
我帮忙写的代码不需要付钱。如果一定要给,请在微信群或QQ群发给大家吧。
【微信公众号、微信群、QQ群】http://bbs.bathome.net/thread-3473-1-1.html
【支持批处理之家,加入VIP会员!】http://bbs.bathome.net/thread-67716-1-1.html

TOP

回复 16# LTSC1809


我说的是19-22这里不对:
for /f "delims=:.tokens=1" %%i in (t2.txt) do set t1h=%%i
for /f "delims=:.tokens=2" %%i in (t2.txt) do set t1m=%%i
for /f "delims=:.tokens=3" %%i in (t2.txt) do set t1s=%%i
for /f "delims=:.tokens=4" %%i in (t2.txt) do set t1ms=%%i
我帮忙写的代码不需要付钱。如果一定要给,请在微信群或QQ群发给大家吧。
【微信公众号、微信群、QQ群】http://bbs.bathome.net/thread-3473-1-1.html
【支持批处理之家,加入VIP会员!】http://bbs.bathome.net/thread-67716-1-1.html

TOP

回复 19# jyswjjgdwtdtj 这样啊,之前一直都是echo然后空格输入内容,原来还可以加逗号,涨知识了

TOP

回复 18# LTSC1809


    防止命令出错
echo输出echo的模式
echo,输出空行
echo,balabala输出balabala

TOP

回复 14# Batcher
echo后面的逗号是什么意思,有什么用?

TOP

返回列表