/**
* 查询指定时间范围内的所有日期,月份,季度,年份
*
* @param string $st 指定开始时间
* @param string $et 指定结束时间
* @param string $type 类型,day 天,month 月份,quarter 季度,year 年份
* @param string $format 时间格式
* @return array
*/
function getDateByInterval(string $st, string $et, string $type, string $format = 'Y-m-d') :array
{
//日期格式不正确
if (strtotime($st) > strtotime($et)) return [];
$returnData = [];
$i = 0;
if ($type == 'day') { // 查询所有日期
do {
$tempDate = date('Y-m-d', strtotime('+' . $i . ' day', strtotime($st)));
$temp = [];
$temp['name'] = date('Y-m-d', strtotime('+' . $i . ' day', strtotime($st)));
$temp['startDate'] = date('Y-m-d', strtotime('+' . $i . ' day', strtotime($st)));
$temp['endDate'] = date('Y-m-d', strtotime('+' . $i . ' day', strtotime($st)));
$temp['format'] = date($format, strtotime('+' . $i . ' day', strtotime($st)));
$returnData[] = $temp;
$i++;
} while (strtotime($tempDate) < strtotime($et));
} elseif ($type == 'month') { // 查询所有月份以及开始结束时间
do {
$temp = [];
$month = strtotime('first day of +' . $i . ' month', strtotime($st));
$temp['name'] = date('Y-m', $month);
$temp['startDate'] = date('Y-m-01', $month);
$temp['endDate'] = date('Y-m-t', $month);
$temp['format'] = date($format, $month);
$tempDate = $temp['endDate'];
$returnData[] = $temp;
$i++;
} while (strtotime($tempDate) < strtotime($et));
} elseif ($type == 'quarter') { // 查询所有季度以及开始结束时间
do {
$temp = [];
$quarter = strtotime('first day of +' . $i . ' month', strtotime($st));
$q = ceil(date('n', $quarter) / 3);
$temp['name'] = date('Y', $quarter) . '第' . $q . '季度';
$temp['startDate'] = date('Y-m-01', mktime(0, 0, 0, $q * 3 - 3 + 1, 1, date('Y', $quarter)));
$temp['endDate'] = date('Y-m-t', mktime(23, 59, 59, $q * 3, 1, date('Y', $quarter)));
$temp['format'] = date($format, mktime(23, 59, 59, $q * 3, 1, date('Y', $quarter)));
$tempDate = $temp['endDate'];
$returnData[] = $temp;
$i = $i + 3;
} while (strtotime($tempDate) < strtotime($et));
} elseif ($type == 'year') { // 查询所有年份以及开始结束时间
do {
$temp = [];
$year = strtotime('+' . $i . ' year', strtotime($st));
$temp['name'] = date('Y', $year) . '年';
$temp['startDate'] = date('Y-01-01', $year);
$temp['endDate'] = date('Y-12-31', $year);
$temp['format'] = date($format, $year);
$tempDate = $temp['endDate'];
$returnData[] = $temp;
$i++;
} while (strtotime($tempDate) < strtotime($et));
}
return $returnData;
}
···
PHP 获取指定时间范围内的所有日期,月份,季度,年份
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。