加入收藏 | 设为首页 | 会员中心 | 我要投稿 淮安站长网 (https://www.0517zz.cn/)- 运营、云管理、经验、智能边缘、云硬盘!
当前位置: 首页 > 教程 > 正文

PHP strtotime计算上一个月的今天问题解决

发布时间:2022-07-22 09:51:15 所属栏目:教程 来源:互联网
导读:PHP,上一个月,strtotime有个小问题:代码如下: php -recho date(Ymd000000,strtotime ( -1 month, strtotime ( 201307310000 ) )); 20130701000000# php -recho date(Ymd000000,strtotime ( -1 month, strtotime ( 201308010000 ) )); 20130701000000# 搜了一
  PHP,上一个月,strtotime有个小问题:代码如下:
 
  > php -r”echo date(‘Ymd000000′,strtotime ( ‘-1 month’, strtotime ( ’201307310000′ ) ));”
  20130701000000#
  > php -r”echo date(‘Ymd000000′,strtotime ( ‘-1 month’, strtotime ( ’201308010000′ ) ));”
  20130701000000#
  搜了一下,下面的方法更准确一些,代码如下:$time = strtotime("2011-03-31");函数 mktime,它可以取得日期的时间戳:
 
  int mktime ([ int $hour [, int $minute [, int $second [, int $month [, int $day [, int $year [, int $is_dst ]]]]]]] )
 
  根据给出的参数返回 Unix 时间戳。时间戳是一个长整数,包含了从 Unix 纪元(January 1 1970 00:00:00 GMT)到给定时间的秒数。
 
  参数可以从右向左省略,任何省略的参数会被设置成本地日期和时间的当前值,所以可以通过它来计算,代码如下:
 
  function last_month_day($time){
      $strtime=mktime(date('h',$time),date('i',$time),date('s',$time),date('m',$time)-1,date('d',$time),date('Y',$time));
      echo date('Y-m-d',$strtime);
  }
   last_month_day(strtotime("2012-03-31"));
  输出的结果是2012-03-02;按理说应该是输出2012-02-31????笨蛋2月有31号吗?没,有30号吗,没?有29号吗?..这个..可以有…
 
  PHP给我们处理了这种情况,他会多出几天按下个月来算.2012年2月最后一天是2012-02-29那么31号比29多两天,所以PHP就累加到下个月来处理 就是2012-03-02啦.差点忘了..那么星期几怎么算呢??不用算啦..PHP给我们准备好了.
 
  date(‘w’,$strtime);输出的就是一周中的第几天.就是星期几了.例代码如下:
 
  /**
   * 计算上一个月的今天,如果上个月没有今天,则返回上一个月的最后一天
   * @param type $time
   * @return type
   */
  function last_month_today($time){
      $last_month_time = mktime(date("G", $time), date("i", $time),
                  date("s", $time), date("n", $time), 0, date("Y", $time));
      $last_month_t =  date("t", $last_month_time);
      if ($last_month_t < date("j", $time)) {
          return date("Y-m-t H:i:s", $last_month_time);
      }
      return date(date("Y-m", $last_month_time) . "-d", $time);
  }
  echo last_month_today($time); 

(编辑:淮安站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读