<?php

/**

 * 功能:取得给定日期所在周的开始日期和结束日期

 * 参数:$gdate 日期,默认为当天,格式:YYYY-MM-DD

 *      $first 一周以星期一还是星期天开始,0为星期天,1为星期一

 * 返回:数组array("开始日期", "结束日期");

 * 

 */

function aweek($gdate = "", $first = 0){

 if(!$gdate) $gdate = date("Y-m-d");

 $w = date("w", strtotime($gdate));//取得一周的第几天,星期天开始0-6

 $dn = $w ? $w - $first : 6;//要减去的天数

 //本周开始日期

 $st = date("Y-m-d", strtotime("$gdate -".$dn." days"));

 //本周结束日期

 $en = date("Y-m-d", strtotime("$st +6 days"));

 //上周开始日期

 $last_st = date('Y-m-d',strtotime("$st - 7 days"));

 //上周结束日期

 $last_en = date('Y-m-d',strtotime("$st - 1 days"));

 return array($st, $en,$last_st,$last_en);//返回开始和结束日期

}

echo implode("|", aweek("", 1)).'<br />';

//echo date("Y-m-d",strtotime("time()"));

echo '本周第一天(星期日为一周开始):'.date('Y-m-d', time()-86400*date('w')).'<br/>';

echo '本周第一天(星期一为一周开始):'.date('Y-m-d', time()-86400*date('w')+(date('w')>0?86400:-6*86400)).'<br/>';

echo '本月第一天:'.date('Y-m-d', mktime(0,0,0,date('m'),1,date('Y'))).'<br/>';

echo '本月最后一天:'.date('Y-m-d', mktime(0,0,0,date('m'),date('t'),date('Y'))).'<br/>';

//上个月的开始日期

$m = date('Y-m-d', mktime(0,0,0,date('m')-1,1,date('Y')));

//上个月共多少天

$t = date('t',strtotime("$m"));

echo '上月第一天:'.date('Y-m-d', mktime(0,0,0,date('m')-1,1,date('Y'))).'<br/>';

echo '上月最后一天:'.date('Y-m-d', mktime(0,0,0,date('m')-1,$t,date('Y'))).'<br/>';

?>

PHP手册上有一个这个方法,用来返回指定日期的周一和周日

<?php
function get_week_range($week, $year)
{
$timestamp = mktime(1,0,0,1,1,$year);
$firstday = date("N",$timestamp);
if($firstday >4)
$firstweek = strtotime('+'.(8-$firstday).' days', $timestamp);
else
$firstweek = strtotime('-'.($firstday-1).' days', $timestamp); $monday = strtotime('+'.($week - 1).' week', $firstweek);
$sunday = strtotime('+6 days', $monday); $start = date("Y-m-d", $monday);
$end = date("Y-m-d", $sunday); return array($start, $end);
}
?> strtotime获取本周第一天和最后一天方法的BUG PHP手册上有一个这个方法,用来返回指定日期的周一和周日 <?php
function get_week_range($week, $year)
{
$timestamp = mktime(1,0,0,1,1,$year);
$firstday = date("N",$timestamp);
if($firstday >4)
$firstweek = strtotime('+'.(8-$firstday).' days', $timestamp);
else
$firstweek = strtotime('-'.($firstday-1).' days', $timestamp); $monday = strtotime('+'.($week - 1).' week', $firstweek);
$sunday = strtotime('+6 days', $monday); $start = date("Y-m-d", $monday);
$end = date("Y-m-d", $sunday); return array($start, $end);
}
?> 但在跨年的时候使用会有问题 例如2009年的12月31日周四和2010年1月1日周五周拿到的周一和周日完全不同 2009年12月31日拿合到的周一和周日分别对应 2009-12-28
2010-01-03 但2010年1月1日拿 到的周一和周日分别对应 2011-01-03
2011-01-09 原因为传进去的方法的周为第53周,但是年为2010年,所以认为2010的第53周,所以计算有误,解决方法为,如果周为大于10(因为一月个月不可能有10周),且月份为1的时候,将年减1处理 if(date('m',$last_week_time) == '01' and $tmp_last_week > 10)
{
$last_week_year--;
}

  

php 本周开始时间和结束时间;本月开始时间结束时间;上月开始时间结束时间的更多相关文章

  1. PHP计算今天、昨天、本周、本月、上月开始时间和结束时间

    PHP计算今天.昨天.本周.本月.上月开始时间和结束时间 $today = date('Y-m-d H:i:s',mktime(0,0,0,date('m'),date('d'),date('Y')) ...

  2. java获取本月开始时间和结束时间、上个月第一天和最后一天的时间以及当前日期往前推一周、一个月

    import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.Date; import java.uti ...

  3. 3.MongoDB恢复探究:为什么oplogReplay参数只设置了日志应用结束时间oplogLimit,而没有设置开始时间?

    (一)问题 在使用MySQL数据库binlog日志基于时间点恢复数据库时,我们必须要指定binlog的开始位置和结束位置,而在MongoDB里面,如果使用oplog进行恢复,只有oplogLimit参 ...

  4. JS获取本周、本季度、本月、上月的开始日期、结束日期

    /** * 获取本周.本季度.本月.上月的开始日期.结束日期 */ var now = new Date();                    //当前日期 var nowDayOfWeek = ...

  5. JS获取本周、本季度、本月、上月、本年的开始日期、结束日期

    /** * 获取本周.本季度.本月.上月的开始日期.结束日期 */ var now = new Date(); //当前日期  var nowDayOfWeek = now.getDay(); //今 ...

  6. js获取时间(本周、本季度、本月..)

    /** * 获取本周.本季度.本月.上月的开端日期.停止日期 */ var now = new Date(); //当前日期 var nowDayOfWeek = now.getDay(); //今天 ...

  7. laydate时间组件在火狐浏览器下有多时间输入框时只能给第一个输入框赋值的问题

    遇到的问题: laydate时间组件在火狐浏览器下有多时间输入框时只能给第一个输入框赋值的问题(safari下也有同样问题); 解决办法: 给laydate绑定id; 解决前代码: <input ...

  8. 时间格式为yyyymmdd的String类型的时间,计算时间间隔有错误

    时间格式类型为yyyymmdd,并且为String类型,计算时间间隔有误,一直搞不清楚是什么原因.网上百度了许多,时间格式基本都是yyyy-mm-dd这样的时间格式的,但是yyyymmdd这样的时间格 ...

  9. Java日期时间API系列39-----中文语句中的时间语义识别(time NLP 输入一句话,能识别出话里的时间)原理分析

    NLP (Natural Language Processing) 是人工智能(AI)的一个子领域.自然语言是人类智慧的结晶,自然语言处理是人工智能中最为困难的问题之一(来自百度百科). 其中中文更是 ...

  10. 时间日期转换工具类,获取当前时间YYYYMMDD24HHMISS、YYYYMMDDHHMISS

    YYYYMMDD24HHMISS:24小时制时间(显示上只是比YYYYMMDDHHMISS中间多了一个24),例:2018102224112440 YYYYMMDDHHMISS:12小时制时间,例20 ...

随机推荐

  1. JetBrains公司介绍(Java、Python、PHP、Ruby、前端和代码测试与重构的IDE)

    JetBrains JetBrains是一家捷克的软件开发公司,该公司位于捷克的布拉格,并在俄国的圣彼得堡及美国麻州波士顿都设有办公室,该公司最为人所熟知的产品是Java编程语言开发撰写时所用的集成开 ...

  2. paper 41:正交变换

    正交变换是保持图形形状和大小不变的几何变换,包含旋转,轴对称及上述变换的复合. 几何意义 正交变换是保持图形形状和大小不变的几何变换,包含旋转,轴对称及上述变换的复合. 代数定义 欧几里得空间V的线性 ...

  3. Oracle11.2新特性之listagg函数 (行列转换)

    SELECT regexp_substr('公司1,贵公司2', '[^,]+', 1, LEVEL, 'i') FROM dualCONNECT BY LEVEL <= length('公司1 ...

  4. mybatis(二)执行CRUD操作的两种方式配置和注解

    一.使用MyBatis对表执行CRUD操作——基于XML的实现 1.定义sql映射xml文件 userMapper.xml文件的内容如下: <?xml version="1.0&quo ...

  5. 夺命雷公狗—angularjs—8—ng-class的简单用法

    我们在正常的业务处理中往往会遇到一些逻辑类的问题,比如各行换色,现在angularjs里面也给我们提供了一个小小的的class处理的方式,废话不多说,如下所示: <!doctype html&g ...

  6. 5. 星际争霸之php设计模式--抽象工厂模式

    题记==============================================================================本php设计模式专辑来源于博客(jymo ...

  7. Inside TSQL Querying - Chapter 3. Query Tuning

    Tuning Methodology When dealing with performance problems, database professionals tend to focus on t ...

  8. COM编程之一 组件

    [1]组件产生的背景 一个应用程序通常是由单个二进制文件组成的. 当应用程序版本发布后一般不会发生任何变化,对于操作系统.硬件以及客户需求的改变都必须要等到修复源代码后且整个应用程序被重新编译才可处理 ...

  9. xxxx

    http://www.cnblogs.com/zhuojun/p/5747999.html

  10. lamp环境编译(实际通过)

    CentOS:5.5Apache:2.2.9PHP:5.2.6MySQL:5.0.41 条件: yum install gccyum install gcc-c++ vi/etc/yum.repos. ...