php 关于日期的一些计算
1、strtotime基本使用
date_default_timezone_set('PRC'); //设置中国时区
echo "今天:", date("Y-m-d", time()), "<br>";
echo "昨天:", date("Y-m-d", strtotime("-1 day")), "<br>";
echo "明天:", date("Y-m-d", strtotime("+1 day")), "<br>";
echo "一周后:", date("Y-m-d", strtotime("+1 week")), "<br>";
echo "一周零两天四小时两秒后:", date("Y-m-d G:H:s", strtotime("+1 week 2 days 4 hours 2 seconds")), "<br>";
echo "下个星期四:", date("Y-m-d", strtotime("next Thursday")), "<br>";
echo "上个周一(大概率本周的周一):" . date("Y-m-d", strtotime("last Monday")) . "<br>";
echo "上周一:" . date("Y-m-d", strtotime("-1 week last Monday")) . "<br>";
echo "一个月前:" . date("Y-m-d", strtotime("2018-03-31 last month")) . "<br>";//一个月前:2018-03-03
echo "一个月后:" . date("Y-m-d", strtotime("2018-01-31 +1 month")) . "<br>";//一个月前:2018-03-03
echo "十年后:" . date("Y-m-d", strtotime("+10 year")) . "<br>";
echo '<hr>';
//省略一些参数
echo date('Y-m-d H:i:s'). '<br/>';
echo strtotime(date('Y')),'----',date('Y-m-d H:i:s',strtotime(date('Y'))). '<br/>';//?????? 20:18:00 从哪来的
echo strtotime(date('Y-m')),'----',date('Y-m-d H:i:s',strtotime(date('Y-m'))). '<br/>';//天 01,时分秒均为00
echo strtotime(date('Y-m-d')),'----',date('Y-m-d H:i:s',strtotime(date('Y-m-d'))). '<br/>';//时分秒均为00
echo strtotime(date('Y-m-d H')),'----',date('Y-m-d H:i:s',strtotime(date('Y-m-d H'))). '<br/>';//时间格式不识别
echo strtotime(date('Y-m-d H:i')),'----',date('Y-m-d H:i:s',strtotime(date('Y-m-d H:i'))). '<br/>';//秒为00
2、本月最后一天
$date = '2018-2-17';
echo '本月最后一天:' . date('Y-m-d', strtotime(date('Y-m-01', strtotime('+1 month'))) - 1) . '<br/>';
echo '某月最后一天:' . date('Y-m-d', strtotime(date('Y-m-01', strtotime($date . ' +1 month'))) - 1) . '<br/>';
//某月共多少天,可用于最后一天
echo date('t', strtotime($date)) . '<br>';
3、往后一个月 +1 month逻辑
strtotime +1 month -1 month逻辑:先将日期转换成合法的年月日,如strtotime("2018-02-29 -1 month") 2018-02-29,转换为2018-03-01。+1 month操作为直接将月份+1,再转换为合法的年月日,如2018-01-31 月份加一个月为2018-02-31,转换为合法的日期就是2018-03-03
echo "一个月后:" . date("Y-m-d", strtotime("2018-01-01 +1 month")) . "<br>";
echo "一个月后:" . date("Y-m-d", strtotime("2018-01-31 +1 month")) . "<br>";
echo "一个月后:" . date("Y-m-d", strtotime("2018-02-01 +1 month")) . "<br>";
echo "一个月后:" . date("Y-m-d", strtotime("2018-02-02 +1 month")) . "<br>";
echo "一个月后:" . date("Y-m-d", strtotime("2018-02-28 +1 month")) . "<br>";
echo "一个月后:" . date("Y-m-d", strtotime("2018-02-28 -1 month")) . "<br>";
echo "一个月后:" . date("Y-m-d", strtotime("2018-02-29 -1 month")) . "<br>";
4、获取一周中某天的日期(如周三)
$date = '2018-2-17';
var_dump(getOneDayInWeek(7, $date)); /**
* @desc 获得某一日期所在周(周一到周日)中的某天
* @param int $search 查找星期几,周一 1,周二 2。。。周六 6,周日7
* @param null $date 基准日期
* @return bool|string
*/
getOneDayInWeek($search, $date = NULL) {
$date = !$date ? date('Y-m-d') : date('Y-m-d', strtotime($date));
$search = intval($search);
if ($search < 1 || $search > 7 || !$date) {
return FALSE;
}
$weeks = ['', 'Mon', 'Tues', 'Wed', 'Thur', 'Fri', 'Sat', 'Sun']; $w = (int)date('w', strtotime($date));
$w === 0 && $w = 7;
$search > $w && $flag = ' next ';
$search < $w && $flag = ' last '; return isset($flag) ? date("Y-m-d", strtotime($date . $flag . $weeks[$search])) : $date;
}
5、类似合同中下月减一天,试用期三个月后减一天
$deviationMonth = 1;
$deviationDay = -1;
$date = '2018-10-1';
var_dump(getNextMonth($date, $deviationMonth, $deviationDay)); /**
* @desc 类似合同中下月减一天,试用期三个月后减一天
* 正常 2018-01-17 --- 2018-02-16,2017-10-01---2017-10-31,2017-10-31 --- 2017-11-30
* 2018-01-28 --- 2018-02-27,2018-01-29 --- 2018-02-28,2018-01-30 --- 2018-02-28,2018-01-31 --- 2018-02-28,2018-02-01 --- 2018-02-28,2018-02-02 --- 2018-03-01,2018-02-03 --- 2018-03-02
* @param null $date 起始日期
* @param int $deviationMonth 向后推几个月
* @param int $deviationDay 向后推几天,一般是向前一天(-1)
* @return bool|string
*/
getNextMonth($date = NULL, $deviationMonth = 1, $deviationDay = -1) {
$timestamp = !$date ? time() : strtotime($date);
$deviationMonth = intval($deviationMonth);
$deviationDay = intval($deviationDay);
if (!$deviationMonth || !$deviationDay || !$timestamp) {
return FALSE;
}
$month = date('Y-m', strtotime(date('Y-m', $timestamp) . ' ' . $deviationMonth . ' month'));
$day = date('d', $timestamp) + $deviationDay; $day > date('t', strtotime($month)) && $day = date('t', strtotime($month)); return date('Y-m-d', strtotime($month . '-' . $day));
}
参考
php 关于日期的一些计算的更多相关文章
- 通过jxl 读取excel 文件中的日期,并计算时间间隔
java读取excel里面的日期会出现相差8小时的问题. 比如excel里面有一个日期是:2012-7-2 17:14:03秒,用Cell cell=readSheet.getCell(colNo, ...
- java截取日期范围并计算相差月数
前两天,媳妇单位让整理excel的某一个单元格内两个日期范围的相差月数,本人对excel操作不是很熟练,便写了个小程序计算了一下,原始需求如下: 计算投资期限的范围,并得到期限范围的相差月数 思路1: ...
- Hibernate中HQL的日期差值计算,可计算相差多少秒
最近有个业务需求就是计算订单创建时间离现在超过 4 小时的订单都查找出来! 那么就需要用到日期函数了. 网上找了一下总共的日期函数有一下几个: CURRENT_DATE() 返回数据库当前日期 时间函 ...
- js日期转化(计算一周的日期)
之前做项目的时候遇到过一个日期转化的问题,一个日期控件和近一天,近七天和近一月的的联动效果.发现自己不会,后来就百度了一下解决了这个问题. 现在抽空又写了一个时间转化的案例(计算一周的日期),因为之前 ...
- MVC 下 ajax调用 日期差值计算
背景: 服务项目已有服务期起止时间From-To 现在要根据用户输入的新的起始时间, 和该服务期的原有区间值, 计算出新的服务期截止时间 即 NewServiceToDateTime = NewSer ...
- Python datetime time 等时间 日期 之间的计算和相互转化
from datetime import datetime, date, timedelta, timezone from time import time, ctime, localtime, st ...
- (013)每日SQL学习:日期的各种计算
1.确定两个日期之间的工作日天数 --确定两个日期之间的工作日天数with x0 as (select to_date('2018-01-01','yyyy-mm-dd') as 日期 from du ...
- JS 中的日期时间操作计算实例
实例 一:已知日期格式为 "YYYY/MM/DD",计算相对于今天的天数差. function fromNow(date){ var mTimes = new Date(date) ...
- <更新日期03-31-2016> 复利计算5.0 <已改进>
作业要求: 1.客户说:帮我开发一个复利计算软件. 完成复利公式计算程序,并成功PUSH到github上. 客户提出: 2.如果按照单利计算,本息又是多少呢? 3.假如30年之后要筹措到300万元的养 ...
- Java 日期加减计算.
1.用Java.util.Calender来实现 Calendar calendar=Calendar.getInstance(); calendar.setTime(new Date()) ...
随机推荐
- rabbitmq 连接測试
1.假设写错了host (如:factory.setHost("locathost"); )报错: Exception in thread "main" jav ...
- php 将网页执行的输出写入到本地文件中
php -f /var/www/html/default/script/lol_score_calculate/calculate.php >>score_calcutelate.log
- RxJava Subject
Subject Subject可以看成是一个桥梁或者代理,在某些ReactiveX实现中(如RxJava),它同时充当了Observer和Observable的角色.因为它是一个Observer,它可 ...
- 8)Linux程序设计入门--线程操作
)Linux程序设计入门--线程操作 前言:Linux下线程的创建 介绍在Linux下线程的创建和基本的使用. Linux下的线程是一个非常复杂的问题,由 于我对线程的学习不时很好,我在这里只是简单的 ...
- ZooKeeper安装和配置(转)
原文链接:http://coolxing.iteye.com/blog/1871009 Zookeeper的安装和配置十分简单, 既可以配置成单机模式, 也可以配置成集群模式. 下面将分别进行介绍. ...
- iOS:本地数据库sqlite的介绍
一.数据库的概念: 1..什么是数据库 SQL Server 2010.Oracle.MySQL 关系数据库 NoSQL数据库-非关系型数据库 数据库主要由表组成 表由字段组成 数据 就是表中的记 ...
- 领扣-209 长度最小的子数组 Minimum Size Subarray Sum MD
Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...
- Java里面类型转换总结
1.String 转 int int i = Integer.valueOf(my_str).intValue(); int i = Integer.parseInt(str); 2.String 转 ...
- java中 HashMap和Hashtable,list、set和map 的区别
摘自: http://blog.chinaunix.net/uid-7374279-id-2057584.html HashMap是Hashtable的轻量级实现(非线程安全的实现),他们都完成了Ma ...
- 如何在mysql数据库中保存emoji特殊字符
MySQL在5.5.3版本之后增加了这个utf8mb4的编码,mb4就是most bytes 4的意思,专门用来兼容四字节的unicode.其实,utf8mb4是utf8的超集,理论上原来使用utf8 ...