Eri*_*len 7 php mysql date strtotime recurring-events
我已经查看过至少二十几个关于此的主题,还没有真正找到一个好的答案,所以我再次请你再次询问有关重复事件的可怕主题的答案.
我现在每天,每周,每月和每年重复都很好(我仍然需要使用异常事件和诸如此类的东西来修改系统,但它暂时有效).但是,我们希望能够在每个月,每隔一个月的[第一,第二,第三,第四,第五] [太阳|周一|周二|周三|周四|周五|周六]添加重复活动的能力,每三个月一次.
现在,如果我能够理解每个月的逻辑,我可以弄清楚每隔一个月和每三个月.
这里有一点我至今(注:我不是说我做什么的最好方式,但该系统是一个我们非常缓慢更新随着时间的推移,当我们不忙于其他项目,所以因为我有时间,所以我使代码更有效率.
首先,我得到格式化日期计算的开始和结束日期:
$ending = $_POST['end_month'] . "/" . $_POST['end_day'] . "/" . substr($_POST['end_year'], 2, 2);
$starting = $_POST['month'] . "/" . $_POST['day'] . "/" . substr($_POST['year'], 2, 2);
Run Code Online (Sandbox Code Playgroud)
然后我得到这两个之间的区别知道有多少次,使用功能我相当肯定,我发现这里对前一段时间将这个金额28天重复进行,以获得只是它需要多少次重复,使每月有一个:
$repeat_number = date_diff($starting, $ending) / 28;
//find the difference in DAYS between the two dates
function date_diff($old_date, $new_date) {
$offset = strtotime($new_date) - strtotime($old_date);
return $offset/60/60/24;
}
Run Code Online (Sandbox Code Playgroud)
然后我将(第一个,第二个,等等......)部分添加到[Sun | Mon | etc ...]部分,以弄清楚他们想要给我的东西如"第一个星期天":
$find = $_POST['custom_number']. ' ' . $_POST['custom_day'];
Run Code Online (Sandbox Code Playgroud)
然后我使用一个循环,运行需要重复的次数(上面的$ repeat_number):
for($m = 0; $m <= $repeat_number; $m++) {
if($m == 0) {
$month = date('F', substr($starting,0,2));
} else {
$month = date('F', strtotime($month . ' + ' . $m . ' months'));
}
$repeat_date = strtotime($find . ' in ' . $month);
}
Run Code Online (Sandbox Code Playgroud)
现在,我知道这个代码不工作,我在同一时间做有止跌回升正确的月份和年份的重复代码,但并不一定会找到的第一个星期二或不管它是正在寻找.
如果有人能指出我正确的方向,那将是非常感激的.我一直潜伏在社区已有一段时间了,刚刚开始尝试积极参与.
提前感谢您提供的任何意见或建议.
这里有一个可能的选择. strtotime
功能强大,语法包括非常有用的位,如全面的相对时间和日期措辞.
您可以使用格式"of"来生成特定月份的第一个到第N个特定工作日.这是一个date_create
用于调用DateTime对象的示例,但是常规old strtotime
工作方式相同:
php > $d = date_create('Last Friday of March 2011'); if($d instanceof DateTime) echo $d->format('l F d Y H:i:s');
Friday March 25 2011 00:00:00
php > $d = date_create('First Friday of March 2011'); if($d instanceof DateTime) echo $d->format('l F d Y H:i:s');
Friday March 04 2011 00:00:00
php > $d = date_create('First Sunday of March 2011'); if($d instanceof DateTime) echo $d->format('l F d Y H:i:s');
Sunday March 06 2011 00:00:00
php > $d = date_create('Fourth Sunday of March 2011'); if($d instanceof DateTime) echo $d->format('l F d Y H:i:s');
Sunday March 27 2011 00:00:00
php > $d = date_create('Last Sunday of March 2011'); if($d instanceof DateTime) echo $d->format('l F d Y H:i:s');
Sunday March 27 2011 00:00:00
Run Code Online (Sandbox Code Playgroud)
如果你要求一个无效的月份,它也会溢出一个月:
php > $d = date_create('Ninth Sunday of March 2011'); if($d instanceof DateTime) echo $d->format('l F d Y H:i:s');
Sunday May 01 2011 00:00:00
Run Code Online (Sandbox Code Playgroud)
请注意,它仅适用于序数编号.不幸的是,你无法通过"第一"或"第三".
一旦你使用它来获取正确的第N个工作日,你可以根据需要简单地添加所需工作日的数量(一周7个,两个14个,三个21个等),直到指定的结束日期或指定的数量为止.几周过去了.再一次,strtotime
救援,使用第二个参数将相对性链接在一起:
php > echo date('l F d Y H:i:s', strtotime('+14 days', strtotime('First Thursday of March 2011')));
Thursday March 17 2011 00:00:00
Run Code Online (Sandbox Code Playgroud)
(我的本地副本也被接受'+14 days First Thursday of March 2011'
,但这感觉有点奇怪.)