ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

php – 在每个月的“第n个”工作日重复事件

2019-10-04 18:14:40  阅读:208  来源: 互联网

标签:strtotime recurring-events php mysql date


我已经查看过至少二十几个关于此的主题,还没有真正找到一个好的答案,所以我再次请你再次询问有关重复事件的可怕主题的答案.

我现在每天,每周,每月和每年重复都很好(我仍然需要使用异常事件和诸如此类的东西来修改系统,但它暂时有效).但是,我们希望能够在每个月,每隔一个月的[第一,第二,第三,第四,第五] [太阳|周一|周二|周三|周四|周五|周六]添加重复活动的能力,每三个月一次.

现在,如果我能够理解每个月的逻辑,我可以弄清楚每隔一个月和每三个月.

这是我到目前为止的一些内容(注意:我并不是说我有最好的方法可以做到这一点或者其他什么,但是当我们不忙于其他项目的时候,系统是我们更新的一个非常缓慢的系统,所以因为我有时间,所以我使代码更有效率.

首先,我得到格式化日期计算的开始和结束日期:

$ending = $_POST['end_month'] . "/" . $_POST['end_day'] . "/" . substr($_POST['end_year'], 2, 2);
$starting = $_POST['month'] . "/" . $_POST['day'] . "/" . substr($_POST['year'], 2, 2);

然后我得到了这两者之间的区别,知道重复使用一个函数的次数,我相当肯定我在前一段时间找到这个函数并将该数量除以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;
}

然后我将(第一个,第二个,等等……)部分添加到[Sun | Mon | etc …]部分,以弄清楚他们想要给我的东西如“第一个星期天”:

$find = $_POST['custom_number']. ' ' . $_POST['custom_day'];

然后我使用一个循环,运行需要重复的次数(上面的$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);
}

现在,我知道这段代码不起作用,我曾经有过一段代码,这些代码为重复发送了正确的月份和年份,但不一定会找到第一个星期二或者其他任何正在寻找的代码.

如果有人能指出我正确的方向,那将是非常感激的.我一直潜伏在社区已有一段时间了,刚刚开始尝试积极参与.

提前感谢您提供的任何意见或建议.

解决方法:

这里有一个可能的选择. strtotime很强大,the syntax includes really useful bits很像comprehensive relative time and date wording.

您可以使用格式“of”来生成特定月份的第一个到第N个特定工作日.这是一个使用date_create来调用DateTime对象的示例,但是常规的旧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

如果你要求一个无效的月份,它也会溢出一个月:

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

请注意,它仅适用于ordinal number的措辞.不幸的是,你无法通过“第一”或“第三”.

一旦你使用它来获取正确的第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

(我的本地副本也接受了“2011年3月第一个星期四的14天”,但这感觉有点奇怪.)

标签:strtotime,recurring-events,php,mysql,date
来源: https://codeday.me/bug/20191004/1853866.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有