這篇文章主要介紹了php日期操作技巧,涉及php日期與時間的顯示格式轉換技巧,具有一定參考借鑒價值,需要的朋友可以參考下
#本文實例總結了php日期操作技巧。分享給大家供大家參考,具體如下:
1、php將表單裡面取得的日期格式轉換成統一的格式
2017-7-9 都統一轉換成2015-09-09 這樣在資料庫都是統一的格式,方便以後查詢
$year = "2017"; $month = "7"; $day = "09"; var_dump(checkdate($month,$day, $year));//月和日带有前导0都是符合格式的 if(checkdate($month,$day, $year)===false){ exit('error'); }; $unixtime = mktime(2,2,2,$month,$day,$year);//目的是交给php转换成月和日都带有前导0的格式统一的格式存储在数据库方便以后查询 var_dump(date("Y-m-d",$unixtime)); ////交给php转换成时间戳,然后反转回来
2、取得上一天的開始時間戳記和結束時間戳
本來思路是:
先用date取得當天的年月日。單獨獲取。得到年是2015 月是9 日是28
然後減1就可以了。但問題出來了。
如果今天是1號呢。減去1就變成0了。上個月可能是28天,也可能是30天。
這樣子,先得到上一天的時間戳記。讓php自動去計算。
strtotime("-1 day"); //得到上一天的时间戳,现在是几点就得到上一天这个时间点的时间戳,用这种方式好处是解决了上面问题,php会自动去计算上个月多少天
<?php header("Content-type:text/html;charset=utf-8"); date_default_timezone_set("Asia/Shanghai");//设置时区 $last_day = strtotime("-1 day");//得到上一天的时间戳,现在是几点就得到上一天这个时间点的时间戳 //通过时间戳得到年月日,以便mktime使用 $year = date("Y",$last_day); $month = date("m",$last_day); $day = date("d",$last_day); $last_day_begin = mktime(0,0,0,$month,$day,$year);//昨天的一天开始的时间戳 $last_day_end = mktime(23,59,59,$month,$day,$year); echo '昨天开始时间戳:'; var_dump($last_day_begin); echo date('Y-m-d H:i:s',$last_day_begin); echo '<br />'; echo '昨天结束时间戳:'; var_dump($last_day_end); echo date('Y-m-d H:i:s',$last_day_end); echo '<br />'; echo ($last_day_end-$last_day_begin)/(60*60);//恰好24个小时
以上是php日期操作技巧小結的詳細內容。更多資訊請關注PHP中文網其他相關文章!