【发布时间】:2011-07-19 19:41:39
【问题描述】:
我已经查看了至少 2 打关于此的主题,但还没有真正找到一个好的答案,所以我再次向您询问有关重复事件的可怕主题的答案。
我现在每天、每周、每月和每年的重复工作都很好(我仍然需要用异常事件和诸如此类的东西来改进系统,但它暂时可以工作)。但是,我们希望能够添加在每个月的(1、2、3、4、5)[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);
}
现在,我知道此代码不起作用,我曾有一次代码可以为重复找到正确的月份和年份,但不一定会找到第一个星期二或其他任何内容正在寻找。
如果有人能指出我正确的方向,将不胜感激。我已经在社区潜伏了一段时间,最近才开始尝试积极参与。
提前感谢您提供的任何意见或建议。
【问题讨论】:
-
不要忘记从月底开始支持相同的模式,或者至少每个月最后一个。
-
你应该重命名你的
date_diff函数——当你升级到PHP 5.3时,它会和the built indate_difffunction冲突。 -
感谢查尔斯提供的信息。我不知道他们添加了 date_diff 函数。
标签: php mysql date strtotime recurring-events