如何使用PHP计算上一个月的今天

   一日,遇到一个问题,求上一个月的今天。 最开始我们使用 strtotime(”-1 month”) 函数求值,发现有一个问题,月长度不一样的月份的计算结果有误。 比如:2011-03-31,得到的结果是2011-03-03。我们先不追究什么问题,先看如何解决问题。 此时,想起PHP中有一个mktime函数,于是自己写了如下代码:

  代码如下:

  echo date("Y-m-d H:i:s", mktime(date("G", $time), date("i", $time),

  date("s", $time), date("n", $time) - 1, date("j", $time), date("Y", $time)));

  当执行时,发现结果和strtotime的结果是一样的。

  还是基于这个函数,既然无法直接操作月,那么我们从天入手,得到上一个月,然后再使用date拼接数据。如下代码:

  复制代码 代码如下:

  $time = strtotime("2011-03-31");

  /**

  * 计算上一个月的今天

  * @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), - 1, date("Y", $time));

  return date(date("Y-m", $last_month_time) . "-d H:i:s", $time);

  }

  echo last_month_today($time);

  但是此时又有了另一个问题,不存在2011-02-31这样的日期,怎么办?现在的需求是对于这样的日期显示当月最后一天。 如下代码:

  代码如下:

  $time = strtotime("2011-03-31");

  /**

  * 计算上一个月的今天,如果上个月没有今天,则返回上一个月的最后一天

  * @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);

  这里需要注意一点: date(”Y-m”, $last_month_time) . “-d”这段代码。在写代码的过程中如果写成了 “Y-” . date(”m”, $last_month_time) . “-d” 则在跨年的时间上有问题。 这点还是在写这篇文章时发现的。

  除了这种方法,还可以先算出年月日再拼接字符串,这里就是纯粹的字符串操作了。

时间: 2024-08-31 01:05:41

如何使用PHP计算上一个月的今天的相关文章

如何使用PHP计算上一个月的今天_php技巧

一日,遇到一个问题,求上一个月的今天. 最开始我们使用 strtotime("-1 month") 函数求值,发现有一个问题,月长度不一样的月份的计算结果有误. 比如:2011-03-31,得到的结果是2011-03-03.我们先不追究什么问题,先看如何解决问题. 此时,想起PHP中有一个mktime函数,于是自己写了如下代码: 复制代码 代码如下: echo date("Y-m-d H:i:s", mktime(date("G", $time)

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

PHP,上一个月 strtotime 有个小问题  代码如下 复制代码 > php -r"echo date('Ymd000000′,strtotime ( '-1 month', strtotime ( '201307310000′ ) ));" 20130701000000# > php -r"echo date('Ymd000000′,strtotime ( '-1 month', strtotime ( '201308010000′ ) ));"

PHP计算上一个月的今天 今天是星期几

 上一个月的今天 strtotime 有个小问题  代码如下 复制代码 > php -r"echo date('Ymd000000′,strtotime ( '-1 month', strtotime ( '201307310000′ ) ));" 20130701000000# > php -r"echo date('Ymd000000′,strtotime ( '-1 month', strtotime ( '201308010000′ ) ));"

如果这个月的第一周在这个月&amp;amp;lt;=3天那么这第一周要归为上一个月的. 用 oracle sql?

问题描述 如果这个月的第一周在这个月<=3天那么这第一周要归为上一个月的. 用 oracle sql? 同样,如果这个月的最后一周在这个月 <=3 天,那么这个最后一周要归为下个月的. 解决方案 如果这个月的最后一周在这个月 <=3 天,那么这个最后一周要归为下个月的

JAVA如何取得上一个月的同一天

问题描述 现在碰到这样一个问题,写一个函数实现取这一天的上个月的那一天.说明:像有些月的前一个月是没有31号的,则默认用这个月的31号去与上个月的30;另外2月份也是一个特殊的月,闰年时为29天,非闰年为28天,所以闰年的3月份的30,31的上个月为29号,非闰年的29,30,31号的上一个月的同一天为28号.还有就是这个月是1月,这上个月是去年的12月. 通过传入一个yyyymmdd的数据,如何实现上述需求,成功取得上一个月的同一天,请各位JAVA高手相助!! 解决方案 public stat

获得上一个月几月

<html><body><%mnth = MonthName(Month(Now))M = Month(Now)If M = 1 Then M2 = M + 11 Else M2 = M - 1mnthprev = MonthName(M2)Response.Write"This month is: "&mnth&"<br>"&_"Last month was: "&mnt

android sqlite查询最近一个月的所有数据怎么查

问题描述 android sqlite查询最近一个月的所有数据怎么查 sqlite我想查最近一个月的数据怎么写?也就是查询今天2016.04.19到上个月2016.03.19的所有数据 表名:work 列名:int id varchar workName timestamp starttime timestamp endtime 怎么查?求大神. 解决方案 select * from work where 日期字段 between date('now', "-1 month") and

嘉宝莉地板新装一个月出现起鼓、脱皮的现象

本报讯 记者罗素静.实习生谭婉春.李玲报道:"花2000多元在省建材大市场'嘉宝莉地板'买的地板,装上一个月就出现起鼓.脱皮的现象,店里没有合意的地板可更换,老板又不给退."8月31日,南昌市民李先生向本报反映称,今年5月底买的嘉宝莉地板7月初就出现问题,却迟迟得不到解决. 李先生告诉记者,5月底,他在省建材大市场的"嘉宝莉地板"专卖店内,花2000多元买了1.5厘米厚的栗红色条纹地板回去装修,7月初地板就出现起鼓.脱皮的现象,"我去店里找了很多次,都没有

嘉宝莉地板新装一个月起鼓脱皮

本报讯 记者罗素静.实习生谭婉春.李玲报道:"花2000多元在省建材大市场'嘉宝莉地板'买的地板,装上一个月就出现起鼓.脱皮的现象,店里没有合意的地板可更换,老板又不给退."8月31日,南昌市民李先生向本报反映称,今年5月底买的嘉宝莉地板7月初就出现问题,却迟迟得不到解决. 李先生告诉记者,5月底,他在省建材大市场的"嘉宝莉地板"专卖店内,花2000多元买了1.5厘米厚的栗红色条纹地板回去装修,7月初地板就出现起鼓.脱皮的现象,"我去店里找了很多次,都没有