【发布时间】:2012-04-26 00:03:02
【问题描述】:
我手动创建了以下数组(底部),我希望仅使用两个易于分解的字符串以编程方式创建它(explode())。
$min_date = '2012-03-01 00:00:00';
$max_date = '2012-04-25 00:00:00';
我已经对字符串进行了explode(),并找出了两个日期之间的月数
$min_date = explode('-',$min_date);
$min_date['year'] = intval($min_date[0]);
$min_date['month'] = intval($min_date[1]);
$min_date['day'] = intval($min_date[2]);
$max_date = explode('-',$max_date);
$max_date['year'] = intval($max_date[0]);
$max_date['month'] = intval($max_date[1]);
$max_date['day'] = intval($max_date[2]);
$months_between = ($max_date['month'] - $min_date['month']) + 12 * ($max_date['year'] - $min_date['year']);
返回 1
cal_days_in_month()函数好像也有用,就是不知道怎么用……
$days_in_month = cal_days_in_month(CAL_GREGORIAN, $month, $year)
这是我手动创建的数组!
$periods = array(
'0' => array(
'month'=>'march',
'week'=>'1',
'days'=>'4',
'readable'=>' Thurs Mar, 01, 2012 - Sun Mar, 04, 2012',
'created_at_min'=>'2012-03-01 00:00:00',
'created_at_max'=>'2012-03-04 24:00:00'
),
'1' => array(
'month'=>'march',
'week'=>'2',
'days'=>'7',
'readable'=>' Mon Mar, 05, 2012 - Sun Mar, 11, 2012',
'created_at_min'=>'2012-03-05 00:00:00',
'created_at_max'=>'2012-03-11 24:00:00'
),
'2' => array(
'month'=>'march',
'week'=>'3',
'days'=>'7',
'readable'=>' Mon Mar, 12, 2012 - Sun Mar, 18, 2012',
'created_at_min'=>'2012-03-12 00:00:00',
'created_at_max'=>'2012-03-18 24:00:00'
),
'3' => array(
'month'=>'march',
'week'=>'4',
'days'=>'7',
'readable'=>' Mon Mar, 19, 2012 - Sun Mar, 25, 2012',
'created_at_min'=>'2012-03-19 00:00:00',
'created_at_max'=>'2012-03-25 24:00:00'
),
'4' => array(
'month'=>'march',
'week'=>'5',
'days'=>'6',
'readable'=>' Mon Mar, 26, 2012 - Sun Mar, 31, 2012',
'created_at_min'=>'2012-03-26 00:00:00',
'created_at_max'=>'2012-03-31 24:00:00'
),
'5' => array(
'month'=>'april',
'week'=>'1',
'days'=>'1',
'readable'=>' Sun Apr, 1, 2012',
'created_at_min'=>'2012-04-01 00:00:00',
'created_at_max'=>'2012-04-01 24:00:00'
),
'6' => array(
'month'=>'april',
'week'=>'2',
'days'=>'7',
'readable'=>' Mon Apr, 2, 2012 - Sun Apr, 8, 2012',
'created_at_min'=>'2012-04-01 00:00:00',
'created_at_max'=>'2012-04-08 24:00:00'
),
'7' => array(
'month'=>'april',
'week'=>'3',
'days'=>'7',
'readable'=>' Mon Apr, 9, 2012 - Sun Apr, 15, 2012',
'created_at_min'=>'2012-04-09 00:00:00',
'created_at_max'=>'2012-04-15 24:00:00'
),
'8' => array(
'month'=>'april',
'week'=>'4',
'days'=>'7',
'readable'=>' Mon Apr, 16, 2012 - Sun Apr, 22, 2012',
'created_at_min'=>'2012-04-16 00:00:00',
'created_at_max'=>'2012-04-22 24:00:00'
),
'9' => array(
'month'=>'april',
'week'=>'5',
'days'=>'3',
'readable'=>' Mon Apr, 23, 2012 - Wed Apr, 25, 2012',
'created_at_min'=>'2012-04-16 00:00:00',
'created_at_max'=>'2012-04-25 00:00:00' // note last day timestamp needs to be 00:00:00
),
);
在我深入研究之前,PHP 提供的任何东西是否可以提供极大的帮助?
$weeks = array(
'may' = array(1,2,3,4,5),
'april' = array(1,2,3,4,5),
);
【问题讨论】:
-
24:00:00不是实时的... :) -
strtotime创建一个 unix 时间戳,这看起来有点疯狂,这是你的意思吗? -
是的。为什么使用可以轻松递增和使用
date的时间戳会很疯狂? -
他认为你的意思是每毫秒循环一次。
标签: php arrays date loops for-loop