PHPで2つの日付の間のすべての日付を取得するにはどうすればよいですか? 日付にはカーボンを使用することをお勧めします。
$from = Carbon::now();
$to = Carbon::createFromDate(2017, 5, 21);
これら2つの日付の間のすべての日付を取得したい..しかし、どのように? strtotime 関数を使用してのみソリューションを見つけることができます。
PHPで2つの日付の間のすべての日付を取得するにはどうすればよいですか? 日付にはカーボンを使用することをお勧めします。
$from = Carbon::now();
$to = Carbon::createFromDate(2017, 5, 21);
これら2つの日付の間のすべての日付を取得したい..しかし、どのように? strtotime 関数を使用してのみソリューションを見つけることができます。
Carbon 1.29 以降では、次のことが可能です。
$period = CarbonPeriod::create('2018-06-14', '2018-06-20');
// Iterate over the period
foreach ($period as $date) {
echo $date->format('Y-m-d');
}
// Convert the period to an array of dates
$dates = $period->toArray();
詳細については、https ://carbon.nesbot.com/docs/#api-period のドキュメントを参照してください。
これが私がそれをやった方法ですCarbon
private function generateDateRange(Carbon $start_date, Carbon $end_date)
{
$dates = [];
for($date = $start_date->copy(); $date->lte($end_date); $date->addDay()) {
$dates[] = $date->format('Y-m-d');
}
return $dates;
}
Carbon は PHP の組み込み DateTime の拡張であるため、DateTime オブジェクトの場合とまったく同じように、DatePeriod と DateInterval を使用できるはずです。
$interval = new DateInterval('P1D');
$to->add($interval);
$daterange = new DatePeriod($from, $interval ,$to);
foreach($daterange as $date){
echo $date->format("Ymd"), PHP_EOL;
}
編集
期間の最終日を含める必要がある場合は、日付を少し変更し$to
、DatePeriod を生成する前に調整する必要があります
$interval = new DateInterval('P1D');
$daterange = new DatePeriod($from, $interval ,$to);
foreach($daterange as $date){
echo $date->format("Ymd"), PHP_EOL;
}
Mark Baker の回答に基づいて、次の関数を作成しました。
/**
* Compute a range between two dates, and generate
* a plain array of Carbon objects of each day in it.
*
* @param \Carbon\Carbon $from
* @param \Carbon\Carbon $to
* @param bool $inclusive
* @return array|null
*
* @author Tristan Jahier
*/
function date_range(Carbon\Carbon $from, Carbon\Carbon $to, $inclusive = true)
{
if ($from->gt($to)) {
return null;
}
// Clone the date objects to avoid issues, then reset their time
$from = $from->copy()->startOfDay();
$to = $to->copy()->startOfDay();
// Include the end date in the range
if ($inclusive) {
$to->addDay();
}
$step = Carbon\CarbonInterval::day();
$period = new DatePeriod($from, $step, $to);
// Convert the DatePeriod into a plain array of Carbon objects
$range = [];
foreach ($period as $day) {
$range[] = new Carbon\Carbon($day);
}
return ! empty($range) ? $range : null;
}
使用法:
>>> date_range(Carbon::parse('2016-07-21'), Carbon::parse('2016-07-23'));
=> [
Carbon\Carbon {#760
+"date": "2016-07-21 00:00:00.000000",
+"timezone_type": 3,
+"timezone": "UTC",
},
Carbon\Carbon {#759
+"date": "2016-07-22 00:00:00.000000",
+"timezone_type": 3,
+"timezone": "UTC",
},
Carbon\Carbon {#761
+"date": "2016-07-23 00:00:00.000000",
+"timezone_type": 3,
+"timezone": "UTC",
},
]
ブール値 ( ) を 3 番目の引数として渡してfalse
、終了日を除外することもできます。
ここに私が持っているものがあります:
private function getDatesFromRange($date_time_from, $date_time_to)
{
// cut hours, because not getting last day when hours of time to is less than hours of time_from
// see while loop
$start = Carbon::createFromFormat('Y-m-d', substr($date_time_from, 0, 10));
$end = Carbon::createFromFormat('Y-m-d', substr($date_time_to, 0, 10));
$dates = [];
while ($start->lte($end)) {
$dates[] = $start->copy()->format('Y-m-d');
$start->addDay();
}
return $dates;
}
例:
$this->getDatesFromRange('2015-03-15 10:10:10', '2015-03-19 09:10:10');