如何解决如何通过在laravel框架中使用Carbon和Eloquent使用特定日期来获得整个开始周和结束周?
我想通过使用特定日期获得整周。 例如,我有一个日期为 2021 年 2 月 3 日星期三。现在我想使用 Eloquent 和 Carbon 获取一周的开始和结束时间,因此输出将是这样的。
2021 年 2 月 1 日 - 星期一
2021 年 2 月 2 日 - 星期二
2021 年 2 月 3 日 - 星期三 - 这是我的日期示例
2021 年 2 月 4 日 - 星期四
2021 年 2 月 5 日 - 星期五
2021 年 2 月 6 日 - 星期六
2021 年 2 月 7 日 - 星期日
解决方法
假设您将示例日期存储在 $date
中。你可以试试下面的代码
$now = Carbon::parse($date);
$weekStartDate = $now->startOfWeek()->format('Y-m-d H:i');
$weekEndDate = $now->endOfWeek()->format('Y-m-d H:i');
见https://carbon.nesbot.com/docs/#api-getters
,您可以在查询中这样做:
$query = "2021-02-03"
$date = Carbon::parse($query);
$startWeek = $date->startOfWeek()->format('Y-m-d');
$endWeek = $date->endOfWeek()->format('Y-m-d');
$q = User::where('date','>=',$startWeek)
->where('date','<=',$endWeek)
->get();
,
$date = CarbonImmutable::parse('2021-02-03');
foreach ($date->startOfWeek()->daysUntil($date->endOfWeek()) as $day) {
echo $day->format('F j,Y - l') . "\n";
}
产生您确切的预期输出:
February 1,2021 - Monday
February 2,2021 - Tuesday
February 3,2021 - Wednesday
February 4,2021 - Thursday
February 5,2021 - Friday
February 6,2021 - Saturday
February 7,2021 - Sunday
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。