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

[其他] 批处理括弧不对称的问题

本帖最后由 meiszp 于 2024-6-28 09:36 编辑

写了一个批处理在远程服务器上运行,系统为windows server 2003 ,远程运行,有时提示“括弧不对称”,输出也是错误的。等一会再运行,可能需要多次尝试,却又不提示,能正确运行。
检查过括弧匹配,set /p 设置也使用了双引号,避免参数里的括弧导致,就是不知原因何在?求指教,谢谢!
  1. @echo off
  2. setlocal enabledelayedexpansion
  3. rem 先清空Log.txt
  4. echo off >Log.txt
  5. for %%f in (*.dat) do (
  6. set "filename=%%~nf"
  7. echo.
  8. echo.>>Log.txt
  9. echo ******************** !filename!.dat ********************
  10. echo ******************** !filename!.dat ********************>>Log.txt
  11. set "start2=!time!"
  12. set /a "startTime2=(1!time:~0,2!-100)*3600+(1!time:~3,2!-100)*60+(1!time:~6,2!-100)"
  13. seal2d.exe !filename!.dat
  14. set "end2=!time!"
  15. rem 格式化显示运行时间
  16. set /a "endTime2=(1!time:~0,2!-100)*3600+(1!time:~3,2!-100)*60+(1!time:~6,2!-100)"
  17. set /a "elapsed2=endTime2-startTime2"
  18. set /a "hh2=elapsed2/3600"
  19. set /a "mm2=(elapsed2%%3600)/60"
  20. set /a "ss2=elapsed2%%60"
  21. echo.
  22. findstr /m  "Program STOP" !filename!.erg
  23. if !errorlevel! neq 1 (
  24. echo 网格太多,程序停止,请查看!filename!.erg文件!
  25. echo 网格太多,程序停止,请查看!filename!.erg文件!>>Log.txt
  26. ) else (
  27. findstr /m  "NaN" !filename!.3dg !filename!.3ds !filename!.erg !filename!.plo !filename!.res !filename!.sav !filename!.val
  28. findstr /m  "NaN" !filename!.3dg !filename!.3ds !filename!.erg !filename!.plo !filename!.res !filename!.sav !filename!.val >>Log.txt
  29. if !errorlevel! neq 1 (
  30. echo 以上输出文件包含"NaN"错误,请检查输入数据!
  31. echo 以上输出文件包含"NaN"错误,请检查输入数据!>>Log.txt
  32. ) else (
  33. echo SEAL2D计算开始时间:!start2!
  34. echo SEAL2D计算开始时间:!start2!>>Log.txt
  35. echo SEAL2D计算结束时间:!end2!
  36. echo SEAL2D计算结束时间:!end2!>>Log.txt
  37. echo SEAL2D计算时长:!hh2!小时 !mm2!分 !ss2!秒
  38. echo SEAL2D计算时长:!hh2!小时 !mm2!分 !ss2!秒>>Log.txt
  39. rem SEAL3D计算
  40. echo.
  41. set "start3=!time!"
  42. echo SEAL3D计算开始时间:!start3!
  43. echo SEAL3D计算开始时间:!start3!>>Log.txt
  44. set /a "startTime3=(1!time:~0,2!-100)*3600+(1!time:~3,2!-100)*60+(1!time:~6,2!-100)"
  45. seal3d.exe !filename!.dat
  46. rem 格式化显示运行时间
  47. set "end3=!time!"
  48. set /a "endTime3=(1!time:~0,2!-100)*3600+(1!time:~3,2!-100)*60+(1!time:~6,2!-100)"
  49. set /a "elapsed3=endTime3-startTime3"
  50. set /a "hh3=elapsed3/3600"
  51. set /a "mm3=(elapsed3%%3600)/60"
  52. set /a "ss3=elapsed3%%60"
  53. echo.
  54. echo SEAL3D计算结束时间:!end3!
  55. echo SEAL3D计算结束时间:!end3!>>Log.txt
  56. echo SEAL3D计算时长:!hh3!小时 !mm3!分 !ss3!秒
  57. echo SEAL3D计算时长:!hh3!小时 !mm3!分 !ss3!秒>>Log.txt
  58. echo.
  59. findstr /m  "NaN" !filename!.3de
  60. findstr /m  "NaN" !filename!.3de>>Log.txt
  61. if !errorlevel! neq 1 (
  62. echo 3de文件包含"NaN"错误,请检查输入数据!
  63. echo 3de文件包含"NaN"错误,请检查输入数据!>>Log.txt
  64. ) else (
  65. echo 3de文件无误!
  66. echo 3de文件无误!>>Log.txt
  67. )
  68. )
  69. )
  70. )
  71. endlocal
  72. echo.
  73. pause
复制代码

回复 1# meiszp


请提供完整代码和报错截图。
如果需要上传文件,请用使用网盘。

如果需要上传截图,可以找个图床,例如:
http://bbs.bathome.net/thread-60985-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

回复 2# Batcher
代码和报错截图已提供,请指教。

TOP

空格问题
time个位数时间时,前面有个空格
例如【 9:11:07.78】9前面有个空格
自己想方法去掉

TOP

本帖最后由 ppll2030 于 2024-6-28 12:49 编辑

time获取的时间如果是上午,得到的小时数为个位数,前面需要补0,你的计算方式才能正确。
所以要在计算秒数的前面,做一下小时数补0的判断就可以了。
  1. if %time:~0,2% leq 9 (set hour=0%time:~1,1%) else (set hour=%time:~0,2%)
  2. set /a "startTime2=(1!hour!-100)*3600+(1!time:~3,2!-100)*60+(1!time:~6,2!-100)"
复制代码

TOP

原因4、5楼已说明。
前面不带0,试试直接计算呢
  1. set /a "startTime2=!time:~0,2!*3600+(1!time:~3,2!-100)*60+(1!time:~6,2!-100)"
复制代码
bat小白,请多指教!谢谢!

TOP

回复 4# Five66
谢谢,一针见血!

TOP

回复 5# ppll2030

谢谢热心回复!

TOP

本帖最后由 meiszp 于 2024-6-28 14:30 编辑

回复 6# 77七
谢谢热心回复!

开始写的是下面代码,但报八进制错误,后来小时、分钟、秒都做补1,减100消除0开头的影响。
  1. set /a "startTime2=!time:~0,2!*3600+!time:~3,2!*60+!time:~6,2!"
复制代码
还有点疑惑,!time:~0,2!取两个字符,为什么就可以?
  1. set /a "startTime2=!time:~0,2!*3600+(1!time:~3,2!-100)*60+(1!time:~6,2!-100)"
复制代码

TOP

回复 9# meiszp

进制这事,我也没学习过,知道这回事就行了,平时用的也不多。可以看以下几个例子
  
  1. set /a n=7
  2. echo %n%
  3. set /a n= 7
  4. echo %n%
  5. set /a n=07
  6. echo %n%
  7. set /a n=08
  8. echo %n%
复制代码
bat小白,请多指教!谢谢!

TOP

回复 9# meiszp

以下示例 一样会报进制错误...
  1. set "t=08:11:12.34"
  2. set/a "_t=(%t:~0,2%*3600)+(%t:~3,2%)*60+(%t:~6,2%)"
复制代码

TOP

本帖最后由 newswan 于 2024-6-30 20:23 编辑

时间计算 做一个函数出来比较方便
  1. call :C_TimeDiff tt t0 t1
  2. call :C_GetDateTime _dt_
  3. :C_GetDateTime
  4. SETLOCAL
  5. for /f "usebackq tokens=1,2 delims==."  %%a in (` wmic os get LocalDateTime /Format:List `) do (
  6. set _%%a_=%%b
  7. )
  8. (
  9. endlocal
  10. set %1=%_LocalDateTime_:~0,4%-%_LocalDateTime_:~4,2%-%_LocalDateTime_:~6,2% %_LocalDateTime_:~8,2%:%_LocalDateTime_:~10,2%:%_LocalDateTime_:~12,2%
  11. )
  12. goto :eof
  13. :C_TimeDiff
  14. SETLOCAL ENABLEDELAYEDEXPANSION
  15. set _t0_=!%2!
  16. set _t1_=!%3!
  17. set _t0_=%_t0_: =0%
  18. set _t1_=%_t1_: =0%
  19. for /f "tokens=1-8 delims=:. " %%a in ( " %_t0_% %_t1_% " ) do (
  20. set/a "_t_=( 1%%e - 1%%a ) * 3600 + ( 1%%f - 1%%b ) * 60 + ( 1%%g - 1%%c )"
  21. )
  22. set/a _HH_=%_t_% / 3600
  23. set/a _mm_=(%_t_% %% 3600) / 60
  24. set/a _ss_=%_t_% %% 60
  25. (
  26. endlocal
  27. set %1=%_HH_%:%_mm_%:%_ss_%
  28. )
  29. goto :eof
复制代码

TOP

返回列表