亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

用于測量代碼運行時的時間和日期時間模塊之間的差異

用于測量代碼運行時的時間和日期時間模塊之間的差異

Helenr 2021-10-26 16:11:22
我正在使用 time 模塊測量函數的響應時間。時間模塊應該將秒數輸出為浮點數,所以我保存了一個開始時間值 (time.clock()) 并在最后讀取另一個讀數,并將差異用作運行時。在觀察結果時,我們注意到運行時間似乎很長——例如,似乎需要不到 2 秒的時間,打印為 3-and-change?;诟兄降膯栴},我決定使用 datetime 模塊仔細檢查結果。并排打印兩個顯示時間模塊值幾乎是日期時間值的兩倍。有誰知道為什么會這樣?這是我的代碼:for datum in data:    start = datetime.datetime.now()    startts = time.clock()    check = test_func(datum)    runtime = datetime.datetime.now() - start    runts = time.clock() - startts    print(check, "Time required:", runtime, "or", runts)我的一些結果:XYZ Time required: 0:00:01.985303 or 3.7836029999999994XYZ Time required: 0:00:01.476289 or 3.3465039999999817XYZ Time required: 0:00:01.454407 or 3.7140109999999993XYZ Time required: 0:00:01.550416 or 3.860824000000008我假設之前會注意到此類問題,而我只是在我的實現中缺少一些基本的東西。有人能指點我嗎?
查看完整描述

2 回答

?
小唯快跑啊

TA貢獻1863條經驗 獲得超2個贊

看起來 time.clock() 自 3.3 版以來已被棄用

也許會有所幫助?

time.clock() 在 Unix 上,將當前處理器時間返回為以秒表示的浮點數。精度,實際上是“處理器時間”含義的定義,取決于同名 C 函數的精度。

在 Windows 上,此函數根據 Win32 函數 QueryPerformanceCounter() 以浮點數形式返回自第一次調用此函數以來經過的掛鐘秒數。分辨率通常優于一微秒。

3.3 版后已棄用:此函數的行為取決于平臺:使用 perf_counter() 或 process_time() 代替,具體取決于您的要求,以獲得明確定義的行為。


查看完整回答
反對 回復 2021-10-26
  • 2 回答
  • 0 關注
  • 221 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號