您好,登錄后才能下訂單哦!
strtotime函數在php項目中的使用方法?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
使用方法如下:
$nowDayDT = strtotime( date('Y-m-d') ); $__startT = microtime(TRUE); for($i=0; $i<$allTime; $i += $gapTime){ $count = 0; //用于數據比較的 $startDT = $nowDayDT+$i; $endDT = $nowDayDT+$i+$gapTime; //用于顯示的 $xAxis1 = date('H:i', $nowDayDT+$i); $xAxis2 = date('H:i', $nowDayDT+$i+$gapTime); foreach($rawData as $line){ $time = strtotime($line['log_dt']); if( $startDT<=$time && $time<$endDT ){ $count ++; } } $resArr[] = [ 'date'=>$xAxis1.'~'.$xAxis2, 'number'=>$count ]; } echo microtime(TRUE)-$__startT;
那這樣的話,基本上是沒辦法再用這個strtotime的函數的了,那還有什么辦法比較時間大小呢?答案很簡單粗暴,PHP里面可以直接比較兩個日期時間字符串!所以改過后的代碼如下。然后現在的運行時間大概是 0.3秒
$__startT = microtime(TRUE); for($i=0; $i<$allTime; $i += $gapTime){ $count = 0; //用于數據比較的 $startDT = date('Y-m-d H:i:s', $nowDayDT+$i); $endDT = date('Y-m-d H:i:s', $nowDayDT+$i+$gapTime); //用于顯示的 $xAxis1 = date('H:i', $nowDayDT+$i); $xAxis2 = date('H:i', $nowDayDT+$i+$gapTime); foreach($rawData as $line){ $time = $line['log_dt']; if( $startDT<=$time && $time<$endDT ){ $count ++; } } $resArr[] = [ 'date'=>$xAxis1.'~'.$xAxis2, 'number'=>$count ]; } echo microtime(TRUE)-$__startT;
遍歷再優化
大家可能發現一個問題,for 里面嵌套一個 foreach,這性能有點擔憂,其中里面的 foreach 有必要完全遍歷嗎?其實是不必的。只要查SQL數據的時候,按時間排序排出來。優化后的時間比較算法如下:
for{ ... foreach($rawData as $line){ $time = $line['log_dt'];//strtotime($line['log_dt']); //優化算法計算 if($time<$startDT) continue; //小于開始時間則跳過 if($time>=$endDT) break; //大于結束時間則結束 $count ++; //否則為符合條件 //原始的算法 // if( $startDT<=$time && $time<$endDT ){ // $count ++; // } } ...}
這里巧用了 continue 和 break 關鍵字,用于跳過一次循環和結束整個循環。這次的話,一天中剛開始的時間統計中,后面很大一部分數據的都可以直接跳過。最后總遍歷時間縮短為約0.12秒 。
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。