這個(gè)是腳本代碼[保存為etime.bat放在當(dāng)前路徑下即可:
代碼如下:
:etime <begin_time> <end_time> <return>
rem 所測試任務(wù)的執(zhí)行時(shí)間不超過1天 // 骨瘦如柴版
setlocal&set be=%~1:%~2&set cc=(%%d-%%a)*360000+(1%%e-1%%b)*6000+1%%f-1%%c&set dy=-8640000
for /f delims=: tokens=1-6 %%a in (%be:.=%)do endlocal&set/a %3=%cc%,%3+=%dy%*(%3>>31)&exit/b
計(jì)算兩個(gè)時(shí)間點(diǎn)差的函數(shù)批處理etime
今天興趣大法思考了好多bat的問題,以至于通宵
在論壇逛看到有個(gè)求時(shí)間差的函數(shù)被打攪調(diào)用地方不少(大都是測試代碼執(zhí)行效率的)
代碼如下:
:time0
::計(jì)算時(shí)間差(封裝)
@echo off&setlocal&set /a n=0&rem code 隨風(fēng) @bbs.bathome.cn
for /f tokens=1-8 delims=.: %%a in (%~1:%~2) do (
set /a n+=10%%a%%100*360000+10%%b%%100*6000+10%%c%%100*100+10%%d%%100
set /a n-=10%%e%%100*360000+10%%f%%100*6000+10%%g%%100*100+10%%h%%100)
set /a s=n/360000,n=n%%360000,f=n/6000,n=n%%6000,m=n/100,n=n%%100
set ok=%s% 小時(shí) %f% 分鐘 %m% 秒 %n% 毫秒
endlocal&set %~3=%ok:-=%&goto :eof
這個(gè)代碼的算法是統(tǒng)一找時(shí)間點(diǎn)凌晨0:00:00.00然后計(jì)算任何一個(gè)時(shí)間點(diǎn)到凌晨的時(shí)間差(單位跑秒)
然后任意兩個(gè)時(shí)間點(diǎn)求時(shí)間差就是他們相對凌晨時(shí)間點(diǎn)的時(shí)間數(shù)的差
對09這樣的非法8進(jìn)制數(shù)的處理用到了一些技巧,還有兩個(gè)時(shí)間參數(shù)不分先后順序,可全可點(diǎn),
但是這個(gè)代碼一行是可以省去的(既然是常被人掉用自然體積越小越好):
代碼如下:
echo off&setlocal&set/a n=0&set s=+:%~1^&echo -:%~2
for /f tokens=1-5 delims=.: %%a in ('echo %s%') do (rem code 隨風(fēng) @bbs.bathome.cn
set/a n%%a=10%%b%%100*360000+10%%c%%100*6000+10%%d%%100*100+10%%e%%100)
set /a s=n/360000,n=n%%360000,f=n/6000,n=n%%6000,m=n/100,n=n%%100
set ok=%s% 小時(shí) %f% 分鐘 %m% 秒 %n% 毫秒
endlocal&(if %3. equ . (echo %ok:-=%) else set %~3=%ok:-=%)&exit/b
再研究下,有更簡短的版本
這個(gè)代碼是我在cn-dos寫過的,今天再優(yōu)化了下更簡短
代碼的算法深入一層:
用hmsw(各字母代表一個(gè)兩位數(shù)字)表示標(biāo)準(zhǔn)時(shí)間
我們記他到凌晨的相對時(shí)間數(shù)為tx
tx=hmsw時(shí)間點(diǎn)-0:00:00.00時(shí)間點(diǎn)=h*3600*100+m*60*100+100*s+w
hmsw 8位10進(jìn)制數(shù)表示的時(shí)間數(shù)(單位0.01秒)就是hmsw跑秒
hmsw=w+100*s+10000*m+1000000*h
hmsw-tx=640000*h+4000*m
所以tx=hmsw-(640000*h+4000*m)=hmsw-4000*(160*h+m)
那么tx_2-tx_1=hmsw_2-hmsw_1-4000*(160*(h_2-h_1)+(m_2-m_1))
對與09這樣的非法8進(jìn)制數(shù)我們給他們每個(gè)前面加上1就可以保證是十進(jìn)制數(shù)又能保證差值不變
對于非同一天的時(shí)間(這種情況較少,除非你在接近0晨時(shí)調(diào)用)我們把用8640000-去替換負(fù)號
再用set/a賦值
就是下面代碼用到的算法
tx_2-tx_1=hmsw_2-hmsw_1-4000*(160*(1h_2-1h_1)+(1m_2-1m_1))
代碼如下:
rem 兼容時(shí)間點(diǎn)跨天的情行,時(shí)間格式00:00:00.00 或者 0:00:00.00 皆可
:_difftime <begin_time> <end_time> [ret] //返回兩個(gè)時(shí)間點(diǎn)的差值(單位0.01秒)
setlocal enabledelayedexpansion&set b=0%1&set e=0%2&set c=1!e:~-11!-1!b:~-11!&set c=!c::=!
set/a c=%c:.=%-4000*(160*(1%e:~-11,-9%-1%b:~-11,-9%)+1%e:~-8,-6%-1%b:~-8,-6%)
endlocal & (if %3.==. (echo %c:-=8640000-%) else set/a %3=%c:-=8640000-%)&exit/b
給difftime前面加上_是為了表明不是臨時(shí)寫的子過程也為了以后連接庫函數(shù)標(biāo)簽的唯一性
// 題外話:對于子過程,若啟用了變量延遲,原則上三行都可以寫完,盡量寫緊湊些(因?yàn)闆]人讀),但是對于算法,思路性的東西要能舍得筆墨,越詳細(xì)越好,我發(fā)現(xiàn)即使你的代碼寫得再好,不會(huì)有人全搬,都會(huì)小修改,
你自己初寫代碼時(shí)不可能考慮到所有人使用的具體情況,自然沒人愿意很詳細(xì)看你的代碼,倒是你的思路為別人提供了一個(gè)方法,在此意義上函數(shù)庫的作用起到方法庫的作用