0

我需要为今天的日期分配一个特定的数字,如 1559,并据此计算前几天和后几天。例如 2 天前是 1557,昨天是 1558,今天是 1559,明天是 1560,等等。这样,我将使用 post 方法为这些天创建一个分页。我的日期采用 YYYY-MM-DD 格式并存储在 mySQL 中的日期变量中。我应该怎么做才能将数字分配给日期并相应地计算日期?

我的代码看起来像这样顺便说一句:

包括('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);
4

1 回答 1

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

请参阅日期时间参考

更新:

$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

于 2011-08-10T06:53:04.930 回答