php - 我需要有关使用 PHP 从一周数中获取天数列表的帮助
问题描述
我想创建一个函数来从一周数和一年中获取天数列表作为参数。
我尝试编写以下函数,该函数仅在我的周数大于 10 时才有效。
public function getDaysofWeek(int $year, int $week){
// ...
$days = array();
for($d=1; $d<8; $d++) {
$days[] = date('d/m/Y', strtotime($year."W". $week .$d));
}
var_dump($days);
// ...
对于 2019 年的第 37 周(今天的一周),我得到了这个(实际上是正确的结果):
array(7) { [0]=> string(10) "09/09/2019"
[1]=> string(10) "10/09/2019"
[2]=> string(10) "11/09/2019"
[3]=> string(10) "12/09/2019"
[4]=> string(10) "13/09/2019"
[5]=> string(10) "14/09/2019"
[6]=> string(10) "15/09/2019" }
但是当我的周数小于 10 时,我得到了这个(这里,2019 年第 5 周):
array(7) { [0]=> string(10) "16/12/2019"
[1]=> string(10) "23/12/2019"
[2]=> string(10) "30/12/2019"
[3]=> string(10) "01/01/1970"
[4]=> string(10) "01/01/1970"
[5]=> string(10) "01/01/1970"
[6]=> string(10) "01/01/1970" }
我不明白为什么会发生这个问题,有人有解释或解决方案吗?
解决方案
问题是,当您在一周中使用整数时,当您将其构建到日期中时
$days[] = date('d/m/Y', strtotime($year."W". $week .$d));
由于日期格式不正确( ),您最终会遇到错误2019W5
,您需要确保您有 2 位数的星期。
这只是格式化一周以确保它以2019W05
...的形式出现
$days[] = date('d/m/Y', strtotime($year."W".
sprintf("%02d", $week) .$d));
推荐阅读
- sql-server - MS SQL -- 从第三个表添加另一个限制
- vue.js - v-bind:class 不使用数组变量
- sql-server - 如何在将数据添加到表中时动态插入日期?
- github - 什么是 GraphQL 查询以确定组织中是否存在 GitHub 包?
- servicestack - 是否可以在 Visual Studio 2017 或 2019 中使用 ServiceStack 模板?
- python - 改进 tensorflow 训练模型
- python - 从大流中选择一个随机元素有什么大不了的?
- javascript - 将 Json 数据映射到新的键值对 JavaScript 对象
- c++ - 如何使用 string::replace 方法写入文件?
- python - Match all identifiers in a string