/**
* 功能:取得給定日期所在周的開始日期和結束日期
* 參數:$gdate 日期,默認爲當天,格式:YYYY-MM-DD
* $first 一週以星期一還是星期天開始,0爲星期天,1爲星期一
* 返回:數組array("開始日期", "結束日期");
*
*/
function aweek( $gdate = "" , $first = 0){
if (! $gdate ) $gdate = date ( "Y-m-d" );
$w = date ( "w" , strtotime ( $gdate )); //取得一週的第幾天,星期天開始0-6
$dn = $w ? $w - $first : 6; //要減去的天數
//本週開始日期
$st = date ( "Y-m-d" , strtotime ( "$gdate -" . $dn . " days" ));
//本週結束日期
$en = date ( "Y-m-d" , strtotime ( "$st +6 days" ));
//上週開始日期
$last_st = date ( 'Y-m-d' , strtotime ( "$st - 7 days" ));
//上週結束日期
$last_en = date ( 'Y-m-d' , strtotime ( "$st - 1 days" ));
return array ( $st , $en , $last_st , $last_en ); //返回開始和結束日期
}
echo implode( "|" , aweek( "" , 1)). '<br />' ;
//echo date("Y-m-d",strtotime("time()"));
echo '本週第一天(星期日爲一週開始):' . date ( 'Y-m-d' , time()-86400* date ( 'w' )). '<hr>' ;
echo '本週第一天(星期一爲一週開始):' . date ( 'Y-m-d' , time()-86400* date ( 'w' )+( date ( 'w' )>0?86400:-6*86400)). '<hr>' ;
echo '本月第一天:' . date ( 'Y-m-d' , mktime (0,0,0, date ( 'm' ),1, date ( 'Y' ))). '<hr>' ;
echo '本月最後一天:' . date ( 'Y-m-d' , mktime (0,0,0, date ( 'm' ), date ( 't' ), date ( 'Y' ))). '<hr>' ;
//上個月的開始日期
$m = date ( 'Y-m-d' , mktime (0,0,0, date ( 'm' )-1,1, date ( 'Y' )));
//上個月共多少天
$t = date ( 't' , strtotime ( "$m" ));
echo '上月第一天:' . date ( 'Y-m-d' , mktime (0,0,0, date ( 'm' )-1,1, date ( 'Y' ))). '<hr>' ;
echo '上月最後一天:' . date ( 'Y-m-d' , mktime (0,0,0, date ( 'm' )-1, $t , date ( 'Y' ))). '<hr>' ;
//PHP手冊上有一個這個方法,用來返回指定日期的週一和週日
function get_week_range( $week , $year ){
$timestamp = mktime (1,0,0,1,1, $year );
$firstday = date ( "N" , $timestamp );
if ( $firstday >4){
$firstweek = strtotime ( '+' .(8- $firstday ). ' days' , $timestamp );
} else {
$firstweek = strtotime ( '-' .( $firstday -1). ' days' , $timestamp );
}
$monday = strtotime ( '+' .( $week - 1). ' week' , $firstweek );
$sunday = strtotime ( '+6 days' , $monday );
$start = date ( "Y-m-d" , $monday );
$end = date ( "Y-m-d" , $sunday );
return array ( $start , $end );
}
//strtotime獲取本週第一天和最後一天方法的BUG
//PHP手冊上有一個這個方法,用來返回指定日期的週一和週日
function get_week_range2( $week , $year ){
$timestamp = mktime (1,0,0,1,1, $year );
$firstday = date ( "N" , $timestamp );
if ( $firstday >4){
$firstweek = strtotime ( '+' .(8- $firstday ). ' days' , $timestamp );
} else {
$firstweek = strtotime ( '-' .( $firstday -1). ' days' , $timestamp );
}
$monday = strtotime ( '+' .( $week - 1). ' week' , $firstweek );
$sunday = strtotime ( '+6 days' , $monday );
$start = date ( "Y-m-d" , $monday );
$end = date ( "Y-m-d" , $sunday );
return array ( $start , $end );
}
但在跨年的時候使用會有問題
例如2011年的12月31日週六和2012年1月1日週日,拿到的週一和週日完全不同
2011年12月31日拿合到的週一和週日分別對應
2011-12-26
2012-01-01
但2012年1月1日拿 到的週一和週日分別對應
2012-01-02
2012-01-04
原因爲傳進去的方法的周爲第53周,但是年爲2011年,所以認爲2011的第53周,所以計算有誤,解決方法爲,
如果周爲大於10(因爲一月個月不可能有10周),且月份爲1的時候,將年減1處理
1
2
3
|
if ( date ( 'm' , $last_week_time ) == '01' and $tmp_last_week > 10){
$last_week_year --;
}
|
|