簡體   English   中英

檢查兩個日期之間的日期-PHP

[英]check a date between two dates - PHP

我想檢查數據庫中存儲的某個日期,如果該日期在本會計年度內,則打印有效;如果不是,則打印無效

這是我的PHP代碼:

$init_date= date("2016/07/01");
$end_date= date("2017/06/30");
$i_date = strtotime($init_date);
$e_date = strtotime($end_date);
$date_db= strtotime($date);// this $date is retrieved from my DB
if ($e_date > $date_db && $i_date < $date_db) 
     { echo "valid";}
else { echo "invalid";}

但是問題是我不想手動設置開始和結束日期,有沒有辦法使它動態? 因為它將每年更新

嘗試這個,

<?php
$start_date = date('Y-m-d', strtotime(str_replace("/", "-", $initdate)));
$end_date   = date('Y-m-d', strtotime(str_replace("/", "-", $end_date)));
$new_date   = date('Y-m-d', strtotime(str_replace("/", "-", $date)));
 if (($start_date < $new_date && $new_date < $end_date) || ($end_date < $new_date && $new_date < $start_date)) {
    echo "valid";
} else {
    echo 'invalid';
}

這是工作鏈接

這樣,您的腳本將更加動態

// the below snippet checks the date retrieved from database
// against fiscal periods between years 2000 and 2050 and return the 
// valid dates
$endYear=2000;
while($endYear<=2050) {
$end = $endYear.'/06/30';
$endDate = DateTime::createFromFormat('Y/m/d', $end);
$initDate = DateTime::createFromFormat('Y/m/d', $end);
$initDate = $initDate->sub(new DateInterval('P1Y'))->add(new DateInterval('P1D'));
$ddb = '2016-09-27';
$dateFrodDB = DateTime::createFromFormat('Y-m-d', $ddb);
if ($dateFrodDB>=$initDate && $dateFrodDB<=$endDate) 
     { echo "valid\n";
         echo "\tStartDate->\"".$initDate->format("Y-m-d")."\"\n";
         echo "\tEndDate->\"".$endDate->format("Y-m-d")."\"\n";
         echo "\tDateFromDatabase->\"".$dateFrodDB->format("Y-m-d")."\"\n";
     }
$endYear++;
}

/* output
   valid
        StartDate->"2016-07-01"
        EndDate->"2017-06-30"
        DateFromDatabase->"2016-09-27"
*/

PHP Sandbox上檢查一下

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM