0

我正在尝试输入在相同时间间隔内发生的事件(每周、双月、每季度、每年)。我展示的脚本是每月的脚本..(如果我能做到这一点,我可以对其他间隔进行调整)。

事件与它们发生的正确周数一起输入。但会出现以下问题:

--- 如何确保少于 31 天的月份没有为其输入事件?----- 如果事件发生在每个第一个和第三个星期五(或任何一个),或每月的最后一个星期四。我如何调整下面的脚本来做到这一点。

谢谢你。

当我插入时,我从 mysql 得到的一个示例......

+----+------+------+------------------+-----------+------------+----------+
| day| month| year | eventname        | eventtime | eventplace | eventweek|
+----+------+------+------------------+-----------+------------+-----------
|  1 |    2 | 2011 | Social Gathering | 12PM      | Room       |   05     |
|  8 |    2 | 2011 | Social Gathering | 12PM      | Room       |   06     |
|  15|    2 | 2011 | Social Gathering | 12PM      | Room       |   07     |
|  22|    2 | 2011 | Social Gathering | 12PM      | Room       |   08     |
|  29|    2 | 2011 | Social Gathering | 12PM      | Room       |   09     |
+----+------+------+------------------+-----------+------------+----------+

PHP 代码

<?php 
    if(isset($_POST['myform'])){

             $day   =   array('1','2','3','4','5','6','7','8','9','10','11','12','13','14','15','16','17','18','19','20','21','22','23','24','25','26','27','28','29','30','31');
             $month =   array('1','2','3','4','5','6','7','8','9','10','11','12');              
             $year  =   array('2011', '2012','2013', '2014', '2015', '2016');   

   $startday   =  mysql_real_escape_string($_POST['day']);
   $eventplace =  mysql_real_escape_string($_POST['eventplace']);
   $eventname  =  mysql_real_escape_string($_POST['eventname']);
   $eventtime  =  mysql_real_escape_string($_POST['eventtime']);

            for($i=0; $i<count($year); $i++){
                for($j=0; $j<count($month); $j++){
                    for($k=$startday; $k<count($day); $k = $k + 7){
                        $date = mktime(0,0,0,$month[$j],$k,$year[$i]); 
                            $week = date('W', $date) ;
      $query = mysql_query(" INSERT INTO caldemo(day, month, year, eventname, eventtime, eventplace, eventweek)
                             VALUES ('".intval($k)."', '".intval($month[$j])."', '".intval($year[$i])."', '".$eventname."', '".$eventtime."', '".$eventplace."', '".intval($week)."' )")or die(mysql_error()) ;
                  }
                }
             } 
          }
?>
4

1 回答 1

0

简单的php解决方案:

function setDatePeriod($months=1, $date='')
{
    if(!$date) $date = date('Y-m-d');
    $d = new DateTime( $date );
    $d->modify( "+{$months} months" );
    return $d->format('Y-m-d');
}
echo setDatePeriod(3);
于 2012-09-21T22:47:00.697 回答