如何通过在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

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...