我创建的应用程序包含很多内容,但重要的是,它需要一个起始日期,并且根据频率和持续时间,它会按日期修改日期。
例如:
$startingDate = new DateTime('2000-01-31');
$duration = 190;
$frequency = 12; //(monthly)
//So, if frequency is monthly, this date will iterative change 190 times by one month
如果我的开始日期是1月31日,而我加1个月,那么它将返回3月2日的日期。 我正在尝试制作一个脚本,以这种方式添加数月:
starting date : 31/01/2000
+1 month = 29/02/2000
+2 months = 31/03/2000
+3 months = 30/04/2000
....
+13 months = 28/02/2001
另一个案例:
Starting date : 28/02/2001
+1 month : 31/03/2001
+2 months : 30/04/2001
...
所以,这个想法是..如果开始日期是当月的最后一天,结束日期必须是一个月的最后一天。
所以,这是我的代码:
// $date came from object
for($i = 0; $i < $duration; $i++){
//calculation stuff
$this->array[$i] = array(
'Date' => $date->format('d/m/y'),
'Capital' => $capital,
'Rate' => $rate,
);
$capital = $remaining;
//end of calculation stuff
$months = (12/$frequency). ' months';
$h = 12/$frequency;
$currentDay = $date->format('d');
if($currentDay == $date->format('t') ) {
if ( $h == 1) {
$date->modify('last day of next month');
$date->modify('last day of next month');
$date->modify('last day of next month');
$date->modify('last day of next month');
$date->modify('last day of next month');
$date->modify('last day of next month');
$date->modify('last day of next month');
$date->modify('last day of next month');
$date->modify('last day of next month');
$date->modify('last day of next month');
$date->modify('last day of next month');
$date->modify('last day of next month');
}
if ( $h == 6) {
$date->modify('last day of next month');
$date->modify('last day of next month');
$date->modify('last day of next month');
$date->modify('last day of next month');
$date->modify('last day of next month');
$date->modify('last day of next month');
}
if ( $h == 4) {
$date->modify('last day of next month');
$date->modify('last day of next month');
$date->modify('last day of next month');
$date->modify('last day of next month');
}
if ( $h == 12) {
$date->modify('last day of next ');
}
} else {
$date->modify($months);
}
}//for
使用此代码,当我将开始日期定为2000年1月31日(本月的最后一天)时,它会以正确的方式给出下一个值:
29/02/00,
31/03/00,
...
28/02/01
...
当我把29/02/2000的开始日期和频率= 2(半年)时,它给了我:
29/02/00,
31/08/00,
28/02/00,
31/08/01 // (right calculations)
这是一个错误: 当我把开始日期定在28/02/2000(不是本月的最后一天)时,它给了我:
28/02/00,
28/08/00,
28/02/01 //(last day in this month),
31/08/01,
28/02/02,
31/08/02,
... //Error here.
当我将开始日期定为30/04/2000和频率每月(12)时,它给了我:
30/04/2000,
30/05/2000,
30/06/2000,
30/07/2000,
30/08/2000,
...
30/01/2001,
02/03/2001,
02/04/2001,
02/05,2001
...
如何修复此错误和/或升级代码?
答案 0 :(得分:0)
“t”返回给定日期的月份天数:
$a_date = "2017-07-23";
echo date("Y-m-t", strtotime($a_date));