php - 在每个月的 "nth"工作日重复事件

标签 php mysql date strtotime recurring-events

我已经查看了至少 2 打与此相关的主题,但还没有真正找到一个好的答案,所以我来找你再次询问有关重复事件这个可怕主题的答案。

我现在每天、每周、每月和每年重复工作正常(我仍然需要用异常事件和诸如此类的东西改造系统,但它暂时工作)。但是,我们希望能够添加在每个月的 (1st,2nd,3rd,4th,5th) [Sun|Mon|Tue|Wed|Thu|Fri|Sat],每隔一个月重复事件的能力,每三个月一次。

现在,如果我能理解每个月的逻辑,我就能算出每隔一个月和每三个月。

这是我到目前为止的一些东西(注意:我并不是说我有最好的方法来做这件事或其他任何事情,但系统是我们在不忙于其他事情时随着时间的推移更新非常缓慢的系统项目,因此我会在有时间的时候使代码更高效)。

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

$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;
}

然后我将 (1st,2nd,etc...) 部分添加到 [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 .

您可以使用它生成特定月份的第一个到第 N 个特定工作日,格式为“of”。这是一个使用 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

(我的本地副本也接受了 '+14 days First Thursday of March 2011',但这感觉有点奇怪。)

关于php - 在每个月的 "nth"工作日重复事件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5380410/

相关文章:

php - 如何将 "OR"条件运算符附加到 MySQL 动态查询 (PHP)?

mysql - Sphinx 索引器错误 : index 'PhoneNumbers2' : Error writing file '/tmp/MYbP6cIt' (Errcode: 28)

MySQL获取每列记录中的子串匹配计数

php - 导出 csv 文件以使用 PHP 从 mysql 下载

php - 使用mysql_real_escape_string存储后保持textarea输入格式

php - 如何使用 PHP 在我的网站上提供即时聊天功能?

java - Hashmap 是否自动排序?

PHP - 格式化 HH :MM:SS to 12hr HH:MM:a string

javascript - 动态添加 jQuery multidatepicker "addDisabledDates"属性

未找到 PHPUnit 类