独立开发者系列(45)——PHP的时间处理详解

2024-08-29 09:28

本文主要是介绍独立开发者系列(45)——PHP的时间处理详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

编程里面,时间函数使用相对比较复杂。变化种类比较多,使用场景也比较丰富。

​ (1)基础用法

在 PHP 中,时间戳是一个整数,表示自 Unix 纪元(1970 年 1 月 1 日 00:00:00 GMT)以来的秒数。使用time()获取当前时间戳
如果需要对时间戳进行格式化使用date(“Y-m-d H:i:s”) 获取当前的时间,按照我们正常的格式输出的时间格式。
如果需要将我们看到的时间2020-10-1 2020-11-15 10:00:00 这种格式转换成时间戳 使用strtotime()函数。有这三个函数和用法,基本可以完成我们日常使用的储存时间/时间戳,判断时间的前后,用时间做筛选条件。

时间使用可以在各种条件下变得非常灵活。列出以下场景。
获取本周一到本周日的日期,或者下周一到下周日的日期。
获取本周是第几周 以星期为单位的活动这个参数非常有用,比如每周签到领奖,每周的课表 每周活动刷新 获取每周的方法 date(“W”)
如果要获取本周是星期几 date(“w”) 这种逻辑可以节约大量的每日签到代码运算量。使用场景: 检查本周是否刷新过活动,用一个当前周的标记刷新了就记录当前周,否则就刷新活动。否则要自己来写判断本周活动是否刷新过的逻辑,需要检查最近刷新日期,通过最近刷新日期,检查是否在一个星期以内,然后再做判断。

获取本周的日期,最常见的就是要看每周的工作汇报,还有每天的不同安排。将数据写入到表里面的时候是,采用的是日期格式,例如2024-08-25这种格式,这个时候,需要读取这些天的相关记录,使用in的方式获取到。

function getDaysThisWeek() {// 获取当前日期$today = getdate();$days = [];for($i=1;$i<8;$i++) {$daysToMonday = $i - $today['wday'];$monday = mktime(0, 0, 0, $today['mon'], $today['mday'] + $daysToMonday, $today['year']);$days[$i]=date('Y-m-d', $monday);}return $days;}

拓展的,根据指定日期,拉取出当周的日期数据(这样就能随时查看每周的相关数据)

   if(!$date) $date = date("Y-m-d");$today = getdate(strtotime($date));

使用场景:读取日历的某一天,拉取出任意星期的日期,然后根据将对应周的数据全部返回出去。查看用户的历史周签到和获奖情况,查看过去的天里面的课表数据。

判断某个传入的时间是不是第一天,因为每个月第一天的时候,会触发各种任务的刷新,游戏里面,一般大型任务都是按月为周期,小型活动是按周设计为周期。统一每个月的第一天刷新全部的任务,获取第一天很简单,读取if(date(“d”)==‘01’),d结构是01-31 第一天表示01,检查到当月第一天 直接判断01。

时间大小的比较。
最直观的是转化成时间戳进行比较 strtotime($date) 这样来判断是否过期 这个仅仅是比较数字大小
第二种,时间日期格式2024-08-01 15:00:08 这种格式也是可以直接进行大小比较的。系统会自动根据时间,日期内部进行对比,写久了时间戳的格式,对这种日期格式直接比较大小,有时候没反应过来,会习惯性的转换成时间戳,来对俩个日期类型的数据进行大小比较。

获取上个月1号 这个月1号 下个月1号 (最常用的时间获取之一,统计函数使用比较多)

//当天的时间戳
$currentDate = date('Y-m-d');
//下个月的时间戳
$nextMonthTimestamp = strtotime('+1 month', strtotime($currentDate));
// 计算上个月的时间戳
$lastMonthTimestamp = strtotime('-1 month', strtotime($currentDate));// 格式化本月 1 号的日期
$firstDay = date('Y-m-01', strtotime($currentDate));
// 计算下个月的时间戳

​ (2)拓展用法
二维数组里面,根据某个时间进行数组内部排序
$arr = [[65,“2024-01-05 16:12:55”],[65,“2024-01-05 13:19:35”],[65,“2024-01-05 16:02:28”]]
对时间进行排序

 $arr = [[65,"2024-01-05 16:12:55"],[65,"2024-01-05 13:19:35"],[65,"2024-01-05 16:02:28"]];usort($arr, function ($a, $b) {return $a[1] <=> $b[1]; //使用了“spaceship”操作符(<=>),它比较两个表达式的值并返回-1、0或1,分别表示$a[1]小于、等于或大于$b[1]。});
print_r($arr); //数组$arr 已经按照变量从小到大排序好

应用场景: 不同的时间录入相关的数据,经过运算之后,拿到了一个二维数组(这里拓展的是录入课表,只与当天的上课时间有关,具体某一天课程,需要从早上9.00——21:00 进行排课,这个时候,拿到了一天的相关数据,需要对上课开始时间进行全新的顺序排列,组装后继续后面逻辑),于是就用到了对二维数组进行时间排序操作。

判断时间能否插入(设计到时间的调度简单算法) 一个时间里面不能做俩件事,所以需要代码逻辑进行区间判断

//将系统的时间格式转换成具体的分钟,这样系统就能准确判断
function isOverlap($existingClasses, $newClassStart, $newClassEnd) {foreach ($existingClasses as $class) {// 将时间段转换为时间戳$start1 = timeToTimestamp($newClassStart);$end1 = timeToTimestamp($newClassEnd);$start2 = timeToTimestamp($class[0]);$end2 = timeToTimestamp($class[1]);// 检查是否有重叠if (($start1 < $end2 && $start1 > $start2) || ($end1 > $start2 && $end1 < $end2)) {return true;}}return false;
}//已经有的课程$exists=[["9:00:00","13:00:00"],["14:00:00","16:00:00"]];//新添加的课程检测 如果该时间段被占据了,就会报错$start = "10:00:00"; $end = "11:00:00";

这篇关于独立开发者系列(45)——PHP的时间处理详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1117468

相关文章

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

poj 2594 二分图最大独立集

题意: 求一张图的最大独立集,这题不同的地方在于,间接相邻的点也可以有一条边,所以用floyd来把间接相邻的边也连起来。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <sta

poj 3692 二分图最大独立集

题意: 幼儿园里,有G个女生和B个男生。 他们中间有女生和女生认识,男生男生认识,也有男生和女生认识的。 现在要选出一些人,使得这里面的人都认识,问最多能选多少人。 解析: 反过来建边,将不认识的男生和女生相连,然后求一个二分图的最大独立集就行了。 下图很直观: 点击打开链接 原图: 现图: 、 代码: #pragma comment(