文档章节

PHP计算时间差

喵先生丿
 喵先生丿
发布于 2017/02/28 09:53
字数 690
阅读 11
收藏 0

这个需求是计算两个时间的差值,当然PHP在5.3版本已经提供了相关的计算函数,本文也会有该函数的示例,除了PHP提供的解决方法之外,这里会再提供几种解决方式以供参考. 需求如下

  1. 差值小于24小时,为今天
  2. 差值小于30天,直接显示剩余天数
  3. 差值大于30天,显示1月之后

内置函数解决方案

使用函数date_diff计算两日期差值,返回的是DateInterval的object数据,直接根据相关需求进行数据处理即可.==注意:传入日期格式,对传入日期进行格式化==,当然关于天的计算标准,需要根据情况来看,比如1月1号到1月5号,系统计算出来的是4天,但是人们会认为1号到5号是5天,这个根据实际情况来进行一个细节处理.


/**
 * 传入日期格式 2017-01-23
 * @param $begin_time
 * @param $end_time
 * @return DateInterval|false
 */
function time_difference ( $begin_time , $end_time ) {
    $datetime1 = date_create ( $begin_time );
    $datetime2 = date_create ( $end_time );
    $interval = date_diff ( $datetime1 , $datetime2 );
    return $interval;
}

输出与结果

//输出
$a = time_difference('2017-1-1','2017-1-5');
var_dump($a);

//结果

object(DateInterval)#3 (15) {
  ["y"]=>
  int(0)
  ["m"]=>
  int(0)
  ["d"]=>
  int(4)
  ["h"]=>
  int(0)
  ["i"]=>
  int(0)
  ["s"]=>
  int(0)
  ["weekday"]=>
  int(0)
  ["weekday_behavior"]=>
  int(0)
  ["first_last_day_of"]=>
  int(0)
  ["invert"]=>
  int(1)
  ["days"]=>
  int(4)
  ["special_type"]=>
  int(0)
  ["special_amount"]=>
  int(0)
  ["have_weekday_relative"]=>
  int(0)
  ["have_special_relative"]=>
  int(0)
}

简单粗暴方式

根据需求,直接使用比较原始,比较有效的方式进行计算即可.当然这种方式的局限性比较大,根据情况自行决定是否使用. 代码示例

$num = strtotime('2017-1-5') - strtotime('2017-1-1');
$diff = floor($num/60/60/24);
if($diff >= 30){
    echo '1月';
}elseif($diff >=1){
    echo ($diff+1).'天'; //这里是否+1自己决定,上面已经说过,不再赘述
}elseif($diff < 1){
    echo '今天';
}

输出结果5天

时间差计算


function time2Units ( $time ) {
    $year = floor ( $time / 60 / 60 / 24 / 365 );
    $time -= $year * 60 * 60 * 24 * 365;
    $month = floor ( $time / 60 / 60 / 24 / 30 );
    $time -= $month * 60 * 60 * 24 * 30;
    $week = floor ( $time / 60 / 60 / 24 / 7 );
    $time -= $week * 60 * 60 * 24 * 7;
    $day = floor ( $time / 60 / 60 / 24 );
    $time -= $day * 60 * 60 * 24;
    $hour = floor ( $time / 60 / 60 );
    $time -= $hour * 60 * 60;
    $minute = floor ( $time / 60 );
    $time -= $minute * 60;
    $second = $time;
    $elapse = '';
    
    $unitArr = array ( '年' => 'year' , 
                       '个月' => 'month' ,
                       '周' => 'week' , 
                       '天' => 'day' ,
                       '小时' => 'hour' ,
                       '分钟' => 'minute' , 
                       '秒' => 'second'
                       );
    
    foreach ( $unitArr as $cn => $u ) {
        if ( $$u > 0 ) {
            $elapse = $$u . $cn;
            break;
        }
    }
    
    return $elapse;
}

输出与解决


//输出
$num = strtotime('2017-1-5') - strtotime('2017-1-1');
echo time2Units ( $num );

//结果
4天

这里就介绍着三种计算时间差的方法,当然计算时间差方法不只是这三种,可以说这种方法根据自己的想法来做,会出现很多种计算方式,可能每个人的做法都不相同,当然最后的计算结果对了才是最重要的.

© 著作权归作者所有

共有 人打赏支持
喵先生丿
粉丝 3
博文 14
码字总数 5275
作品 0
天津
程序员
js 计算两个时间的时间差

写在前面: 如题,就像题目说的需要计算出时间差,虽然不太难,但这个需求经常会在项目中遇到的,我在这边做一下整理,希望能够尽量全的整理出来。有需要的朋友可以做一下参考,喜欢的可以点...

OB丶Koro1
2017/10/16
0
0
在oracle中计算时间差

计算时间差是oracle data数据类型的一个常见问题。oracle支持日期计算,你可以创建诸如“日期1-日期2”这样的表达式来计算这两个日期之间的时间差。 一旦你发现了时间差异,你可以使用简单的...

1880106122065705
2010/12/09
0
0
帮我设计一个更高效的sql语句

数据库一个表,有id,type(类型)和getdate(时间),要求所有type为2的项,计算离它最近的type为1的项的时间差,并统计出这个时间差的最大前十,最短前十,以及平均值。 我现在是最原始的方...

chencliff
2011/07/18
522
9
Sprite kit 每秒间隔 update 频率伪造

今天用spritekit做了一个小游戏,很好用是很好用但是非常困惑的是里面竟然没有从上次更新到现在的时间差传入方法中,这样的话,我想在update方法中实现每两秒发射一个子弹的功能就变得不好办...

孙启超
2014/01/21
0
0
System.nanoTime与System.currentTimeMillis比较

currentTimeMillis返回的是系统当前时间和1970-01-01之前间隔时间的毫秒数,如果系统时间固定则方法返回值也是一定的(这么说是为了强调和nanoTime的区别),精确度是毫秒级别的 nanoTime的返...

职业搬砖20年
09/06
0
0

没有更多内容

加载失败,请刷新页面

加载更多

arcgis jsapi接口入门系列:总览

开发环境: arcgis jsapi版本4.9 由于我们这套代码是基于vue,webpack开发的,会有少数vue代码,但总体不影响 里面还有些我们公司的js库和html css,给出的代码不能百分百直接运行,主要还是...

canneljls
22分钟前
1
0
月薪80k阿里架构师漫谈他是如何从一名小码农走到架构师的

01 刚当程序员时,我是属于那种勤勤恳恳类型的员工,工作态度用认真来形容不为过,每天我几乎是团队里最早到公司,又最晚下班的一个。而组员张工一般情况下都是准时上下班的,即使项目进度比...

Java填坑之路
25分钟前
1
0
oracle的resetlogs机制浅析

oracle的resetlogs机制浅析 alter database open resetlogs 这个命令我想大家都很熟悉了,那有没有想过这个resetlogs选项为什么要用?什么时候用? 它的原理机制是什么?他都起哪些作用? 我...

突突突酱
26分钟前
1
0
JAVA 获取两个日期间的所有日期

public static List<String> getDates(String startDate, String endDate){ List<String> dates = new ArrayList<>(); try { SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMdd"); Dat......

尘叙缘
33分钟前
2
0
Innodb中的事务隔离级别和锁的关系

#一次封锁or两段锁? 因为有大量的并发访问,为了预防死锁,一般应用中推荐使用一次封锁法,就是在方法的开始阶段,已经预先知道会用到哪些数据,然后全部锁住,在方法运行之后,再全部解锁。...

Skqing
47分钟前
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部