- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一组工作时间,并希望生成一个建议类次列表,所有这些都基于当前的“现在”时间并倒退到过去。
例如小时模板:
$templateShifts = collect([
(object)[
"id" => 1,
"from_day" => 1, // mon
"from_time" => "09:00:00",
"until_day" => 1,
"until_time" => "12:00:00",
],
(object)[
"id" => 2,
"from_day" => 1, // mon
"from_time" => "13:00:00",
"until_day" => 1,
"until_time" => "17:00:00",
],
(object)[
"id" => 3,
"from_day" => 2, // tue
"from_time" => "09:00:00",
"until_day" => 2,
"until_time" => "17:00:00",
],
(object)[
"id" => 4,
"from_day" => 4, // thur
"from_time" => "09:00:00",
"until_day" => 4,
"until_time" => "17:00:00",
],
(object)[
"id" => 5,
"from_day" => 5, // fri
"from_time" => "09:00:00",
"until_day" => 5,
"until_time" => "17:00:00",
]
]);
如果今天是星期四(1 月 4 日),它应该以相反的顺序列出日期:
// Paging
$total_count = 1000;
$on_page = 30;
$page = $request->get('page') ?: 1;
$skip = $on_page * ($page - 1);
// Find closest match in the past from now
$date = now();
$year = $date->year;
$weekNo = $date->weekOfYear;
$shifts = collect();
// Decrement week no
if ($skip) {
$weekNo -= $skip;
// Change year till positive weekNo
while ($weekNo < 1) {
--$year;
$date->subYear();
$weekNo += $date->isoWeeksInYear;
}
}
// First page
if (!$skip) {
// First search for shift today
$firstShiftIndex = $templateShifts->search(function ($item, $key) use ($date) {
return $item->from_day == $date->format('N') && $item->from_time <= $date->format('H:i:s');
});
$currentWeekNo = false;
if ($firstShiftIndex === false) {
// Loop back from today till find a matching day
for ($i = 1; $i <= 7; $i++) {
$date = $date->clone()->subDays(1);
$firstShiftIndex = $templateShifts->search(function ($item, $key) use ($date) {
return $item->from_day == $date->format('N');
});
if ($firstShiftIndex !== false) {
$year = $date->year;
$weekNo = $date->weekOfYear;
break;
}
}
}
$templateShifts->slice($firstShiftIndex)->each(function ($item, $key) use ($shifts, $date, $year, $weekNo) {
$shift_from = $date->clone()->setISODate($year, $weekNo, $item->from_day);
list($hour, $minutes) = explode(':', $item->from_time);
$shift_from->setTime($hour, $minutes);
// Crosses into next week/maybe year too
if ($item->until_day < $item->from_day) {
$weekNo++;
if ($weekNo < 1) {
--$year;
$date->subYear();
$weekNo = $date->isoWeeksInYear;
}
}
$shift_until = $date->clone()->setISODate($year, $weekNo, $item->until_day);
list($hour, $minutes) = explode(':', $item->until_time);
$shift_until->setTime($hour, $minutes);
if ($shift_from->toDateString() == $shift_until->toDateString()) {
$name = $shift_from->format('d/m/Y D H:i') . ' - ' . $shift_until->format('H:i');
} else {
$name = $shift_from->format('d/m/Y D H:i') . ' - ' . $shift_until->format('D H:i');
}
$shifts->push([
'id' => $item->id,
'text' => $name
]);
});
}
//
for($i=0; $i < $on_page; $i++) {
--$weekNo;
if ($weekNo < 1) {
--$year;
$date->subYear();
$weekNo = $date->isoWeeksInYear;
}
$templateShifts->each(function ($item, $key) use ($shifts, $date, $year, $weekNo) {
$shift_from = $date->clone()->setISODate($year, $weekNo, $item->from_day);
list($hour, $minutes) = explode(':', $item->from_time);
$shift_from->setTime($hour, $minutes);
// Crosses into next week/maybe year too
if ($item->until_day < $item->from_day) {
$weekNo++;
if ($weekNo < 1) {
--$year;
$date->subYear();
$weekNo = $date->isoWeeksInYear;
}
}
$shift_until = $date->clone()->setISODate($year, $weekNo, $item->until_day);
list($hour, $minutes) = explode(':', $item->until_time);
$shift_until->setTime($hour, $minutes);
if ($shift_from->toDateString() == $shift_until->toDateString()) {
$name = $shift_from->format('d/m/Y D H:i') . ' - ' . $shift_until->format('H:i');
} else {
$name = $shift_from->format('d/m/Y D H:i') . ' - ' . $shift_until->format('D H:i');
}
$shifts->push([
'id' => $item->id,
'text' => $name
]);
});
}
最佳答案
首先,您的预期数据似乎有误,因为 1 月 4 日不是星期四(实际上我的生日是星期一)。
这是一个棘手的问题,因为有多个问题需要解决,我将其分为 3 个阶段。
->subWeek()->endOfWeek(Carbon::SUNDAY)
.
$now = Carbon::parse('2021-01-04')->endOfDay();
$suggestions = collect();
while ($suggestions->count() <= 30) {
$suggestedShifts = $this->suggestShifts($now);
$suggestions->push(... $suggestedShifts);
$now->subWeek()->endOfWeek(Carbon::SUNDAY);
}
suggestShifts()
方法如下。将所有类次映射到当前周,如果类次大于我们正在比较的日期,则忽略它,这仅在您第一次通过时才成立。设置轮类日期并计算与我们正在比较的日期的差异,这将按并确保建议的下一个类次是当前日期的壁橱。
private function suggestShifts(Carbon $date)
{
return $this->shifts->map(function ($shift) use ($date) {
if ($shift->until_day > $date->dayOfWeekIso) {
return null;
}
$untilTime = explode(':', $shift->until_time);
$shift->date = $date->clone()->subDays($date->dayOfWeekIso - $shift->until_day)->setTime($untilTime[0], $untilTime[1], $untilTime[2]);
$shift->diff = $date->diff($shift->date)->h;
return clone $shift;
})->filter()
->sortByDesc(function ($shift) {
return $shift->date->timestamp;
})->all();
}
我不确定这是最快的路线,但它的代码相当干净和可读,应该让你朝着正确的方向前进。也不是建议是附有日期的类次对象。我的日期比较使用直到时间,如果你想改变开始时间,你应该很容易做到这一点。此代码在本地执行,结果如下。像这样打印出来。再次注意,1 月 4 日是星期一。
$this->shifts
, 是您的轮类结构粘贴在属性上。
$suggestions->each(function ($shift) {
$this->info('Shift: ');
$this->info('starting - ' . $shift->date->clone()->setHour(explode(':', $shift->from_time)[0])->toIso8601ZuluString());
$this->info('ending - ' . $shift->date->toIso8601ZuluString());
});
Shift:
starting - 2021-01-04T13:00:00Z
ending - 2021-01-04T17:00:00Z
Shift:
starting - 2021-01-04T09:00:00Z
ending - 2021-01-04T12:00:00Z
Shift:
starting - 2021-01-01T09:00:00Z
ending - 2021-01-01T17:00:00Z
Shift:
starting - 2020-12-31T09:00:00Z
ending - 2020-12-31T17:00:00Z
Shift:
starting - 2020-12-29T09:00:00Z
ending - 2020-12-29T17:00:00Z
Shift:
starting - 2020-12-28T13:00:00Z
ending - 2020-12-28T17:00:00Z
Shift:
starting - 2020-12-28T09:00:00Z
ending - 2020-12-28T12:00:00Z
Shift:
starting - 2020-12-25T09:00:00Z
ending - 2020-12-25T17:00:00Z
Shift:
starting - 2020-12-24T09:00:00Z
ending - 2020-12-24T17:00:00Z
Shift:
starting - 2020-12-22T09:00:00Z
ending - 2020-12-22T17:00:00Z
Shift:
starting - 2020-12-21T13:00:00Z
ending - 2020-12-21T17:00:00Z
Shift:
starting - 2020-12-21T09:00:00Z
ending - 2020-12-21T12:00:00Z
Shift:
starting - 2020-12-18T09:00:00Z
ending - 2020-12-18T17:00:00Z
Shift:
starting - 2020-12-17T09:00:00Z
ending - 2020-12-17T17:00:00Z
Shift:
starting - 2020-12-15T09:00:00Z
ending - 2020-12-15T17:00:00Z
Shift:
starting - 2020-12-14T13:00:00Z
ending - 2020-12-14T17:00:00Z
Shift:
starting - 2020-12-14T09:00:00Z
ending - 2020-12-14T12:00:00Z
Shift:
starting - 2020-12-11T09:00:00Z
ending - 2020-12-11T17:00:00Z
Shift:
starting - 2020-12-10T09:00:00Z
ending - 2020-12-10T17:00:00Z
Shift:
starting - 2020-12-08T09:00:00Z
ending - 2020-12-08T17:00:00Z
Shift:
starting - 2020-12-07T13:00:00Z
ending - 2020-12-07T17:00:00Z
Shift:
starting - 2020-12-07T09:00:00Z
ending - 2020-12-07T12:00:00Z
Shift:
starting - 2020-12-04T09:00:00Z
ending - 2020-12-04T17:00:00Z
Shift:
starting - 2020-12-03T09:00:00Z
ending - 2020-12-03T17:00:00Z
Shift:
starting - 2020-12-01T09:00:00Z
ending - 2020-12-01T17:00:00Z
Shift:
starting - 2020-11-30T13:00:00Z
ending - 2020-11-30T17:00:00Z
Shift:
starting - 2020-11-30T09:00:00Z
ending - 2020-11-30T12:00:00Z
Shift:
starting - 2020-11-27T09:00:00Z
ending - 2020-11-27T17:00:00Z
Shift:
starting - 2020-11-26T09:00:00Z
ending - 2020-11-26T17:00:00Z
Shift:
starting - 2020-11-24T09:00:00Z
ending - 2020-11-24T17:00:00Z
Shift:
starting - 2020-11-23T13:00:00Z
ending - 2020-11-23T17:00:00Z
Shift:
starting - 2020-11-23T09:00:00Z
ending - 2020-11-23T12:00:00Z
关于php - 从今天开始循环以从一组模板生成类次/轮类列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67461452/
我找到了很好的函数 =GOOGLEFINANCE("AAPL";"price";TODAY(); today()-60) 可以给出指定日期范围内的股票价格 - 它工作正常。我试图用它来获取 EPS 或
基于云计算的大规模即时云渲染技术,让每个人都拥有了“数字生命”。 2023的开年爆款,非《流浪地球2》莫属。 它展开了人类的新话题,关于平行空间,关于数字生命,关于人类文明
我试图过滤掉比今天更大的日期。我查找了语法,但日期部分不起作用;我仍然在结果中得到日期 > 今天。 有人可以帮我解决这个问题吗?!谢谢!这是查询: =iferror(sort(if(isblank(S
这就是我现在所拥有的: set_time_limit(120); $now = (new \DateTime)->format('Y-m-d H:i:s'); $nowYmd = (new \Date
这个问题在这里已经有了答案: 关闭 12 年前。 Possible Duplicate: Select * from table where date = today 你好,我正在尝试做一个 mys
我使用 CouchDB 作为事件日志,我想在它之上构建简单的 UI,以便我可以更轻松地查询事件。 我可以使用原始 HTTP 调用并手动构建 View ,也可以使用 CouchApp 框架。 问题是这些
我似乎无法在“小部件模拟器”中运行“今日”小部件(或与此相关的任何扩展名)。模拟器启动,并说“无法打开小部件”以及 Failed to find Widget /Users/SomeUser/Libr
我正在使用来自此来源的日期选择器 http://jqueryui.com/datepicker/#buttonbar ,我正在尝试让按钮栏上的“今天”按钮处于事件状态,请任何人帮助我。 $(".dat
我是Prometheus和警报方面的新手,我无法通过查看文档来完善答案。 我有一些数据即将进入Elasticsearch集群。每天,该过程都会在Elasticsearch上创建一个新索引,并将当天的数
我有一个应用程序和一个今天的扩展程序,它们使用安全组标识符共享Core Data持久性存储。 主应用程序更新Core Data存储,而扩展名仅从存储中读取。 我在应用程序和扩展程序中都使用了NSFet
我在项目中完成了Today扩展的一半。 我不必向公众发布半成品,但也希望保持相同的代码库,这样可以节省代码维护时间。 没有人知道没有内置“今日”扩展程序的发布应用程序的方法吗? 谢谢 最佳答案 在应用
我花了很长时间来了解段注册的内容目的是?我已经准备好知道这来自过去 (8086)只有 1 MByte 的物理内存。但是CPU有只有 16 位宽的地址寄存器。有了这 16 个地址位你只能寻址 64K 字
我有一个表格,其中包含成员(member)加入俱乐部时输入的日期。该列是沼泽标准,类型为 DATE。不需要时间。 基本上,我正在尝试找到一种 future 不可能的方式? 最佳答案 您可以使用触发器。
我需要获取早于或等于今天的日期。我正在使用 C# LINQ。 只是想知道以下是否是最有效的方法: pr.PgDate >= DateTime.Today 最佳答案 视情况而定,假设您使用的是将其直接转
$str = 'BEGIN This is a "quote" test. \'Single\' END'; echo $str . "\n"; echo mysql_real_escape_stri
在 HTML 5 中是否支持在 Silverlight 中真正容易做到的事情? 例如,将一个文件(由用户选择)转换为一个字节数组,该字节数组可以进行 base64 编码并传递给网络服务? 或者,创建/
使用 Oracle,如何在 11:59:59 选择当前日期(即 SYSDATE)? 考虑到午夜的定义might be a little ambiguous (星期四午夜是指跨越星期四和星期五还是跨越星
My Today 扩展需要有一个基于小部件显示内容的动态高度。我能够通过在最底部元素上添加约束来实现这一点:底部布局指南的顶部小于或等于最底部元素的底部,常量为 0,优先级为 999,乘数为 1。 这
我相信你们中的许多人已经查看了今天的 (2011-02-08) Google's doodle (link to article on CNN if doodle changes)。这太棒了,我试着弄
如下所示: ? 1
我是一名优秀的程序员,十分优秀!