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′ ) ));”
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);

时间: 2024-09-10 08:28:15

PHP strtotime计算上一个月的今天问题解决的相关文章

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

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

如何使用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 -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月初地板就出现起鼓.脱皮的现象,"我去店里找了很多次,都没有