2011-08-10 67 views
0

我需要为当前日期指定一个特定的数字,如1559,并根据此计算前几天和下一天。例如2天前是1557,昨天是1558,今天是1559,明天是1560,等等。因此,我将使用post方法为日期创建分页。我的日期采用YYYY-MM-DD格式,并存储在mySQL的日期变量中。我应该如何分配数字来计算日期并据此计算日期?指定日期变量

我的代码看起来像这样BTW:

包括( 'connect.php');

date_default_timezone_set("Etc/GMT+7"); 
    $timestamp= date("Y-m-d"); 
    $day1=1357; 

    echo ('<form action="total_inf.php" method="post" name="inf_day">'); 
    for($i=0;$i<10;$i++) 

    { 
    $newdate=strtotime('-$i days',strtotime($timestamp)); 
    $newdate = date ('Y-m-d' , $newdate); 

    $prevdays=$day1-$i; 

    print ('<input type="submit" name="bugun" value="'.$prevdays.'">&nbsp;'); 

    } 
    echo ('</form>');  

    $day_selected=$_POST[bugun]; 

    $sql1="SELECT * FROM userdata WHERE zaman='$timestamp'"; 
    $result1=mysql_query($sql1,$conn); 
+0

为什么不使用适当的完整日期? – 2011-08-10 06:53:32

回答

0
$current_date = new DateTime('2011-08-10'); 
$current_date->modify('+1 day'); //next day 
$current_date->modify('-1 day');// prev day 

$other_date = new DateTime('1970-01-01'); //another date 

参见DateTime reference

UPDATE:

$day1 = new DateTime(); 
$day1->modify('-1357 days'); 
//if you need it to be some fixed date, use $day1= new DateTime("2011-08-01"); 

$now_date = new DateTime(); 
for($i=0;$i<10;$i++){ 
    $date_diff = $now_date->diff($zero_date); 
    $prevdays = $date_diff->format("#a")-$i; 
    print ('<input type="submit" name="bugun" value="'.$prevdays.'">&nbsp;'); 
} 

作品用PHP> = 5.3.0。请参阅DateInterval::format

+0

约翰,谢谢你的帮助,但是我没有得到从今天的日期开始如何生成诸如“第1550天”之类的东西,从而使其成为参考日,并且计算明天为1551天,而在昨天为1549天。为未来数百天。我的代码看起来像这样顺便说一句: –