0

1559 のような特定の数字を今日の日付に割り当て、これに従って前後の日を計算する必要があります。たとえば、2日前は1557、昨日は1558、今日は1559、明日は1560などです。私の日付は YYYY-MM-DD 形式で、mySQL の日付変数に格納されています。数値を日付に割り当て、それに応じて日付を計算するにはどうすればよいですか?

私のコードは次のようになります。

include ('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

DateTime リファレンスを参照してください

アップデート:

$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 に答える