微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何通过在laravel框架中使用Carbon和Eloquent使用特定日期来获得整个开始周和结束周?

如何解决如何通过在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 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?