独立开发者系列(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";


你可能感兴趣的:(转型独立开发者,php)