怎么通过PHP实现给定年月日计算总天数-阿里云开发者社区

开发者社区> dasein58> 正文

怎么通过PHP实现给定年月日计算总天数

简介: 在之前的文章《PHP数组学习之使用冒泡算法对元素进行升序排序!》中,我们介绍了使用冒泡算法对数组元素进行升序排序的方法。这次我们来看看使用PHP如何实现给定年月日计算是这一年的第几,感兴趣的朋友可以学习了解一下~ 本文的主题是通过PHP实现:输入某年某月某日(例如2000年3月5日),计算至此一共有多少天(也可是判断这一天是这一年的第几天)。
+关注继续查看

在之前的文章《PHP数组学习之使用冒泡算法对元素进行升序排序!》中,我们介绍了使用冒泡算法对数组元素进行升序排序的方法。这次我们来看看使用PHP如何实现给定年月日计算是这一年的第几,感兴趣的朋友可以学习了解一下~
本文的主题是通过PHP实现:输入某年某月某日(例如2000年3月5日),计算至此一共有多少天(也可是判断这一天是这一年的第几天)。

实现思想分析:

想要计算截止3月5这一天一共有多少天,我们可以将从1月1日—3月5日的所有天数都加在一起即可。

那么就需要分别求3月之前几个月(1月和2月)的最大天数,而求一个月的最大天数我们可以使用以下函数来实现这个功能【详细的介绍,可以阅读文章《PHP如何利用函数来计算给定年月的最大天数》】

function GetMaxDay($year,$month){
$time = strtotime("{$year}-{$month}"); //取得一个日期的 Unix 时间戳;
$date=date("t",$time);
return $date;
}
测试一下:输出2000年2月的最大天数

echo GetMaxDay(2000,2);
1.png

因为2000年是闰年,所以2月共有29天,OK可以。

然后就需要将这些最大天数相加起来,这就需要使用循环了(我使用for循环)。一年都是从1月开始的,所以初始条件为 $i=1 ;一直要相加到指定月(3月)之前,所以限制条件为 $i<$month 。

$sum=0;
for($i=1;$i<$month;$i++){
$sum += GetMaxDay($year,$i);
}
测试一下,计算2000年3月之前的所有天数(31+29=60),看看是不是60天:

3.png

OK,功能实现了!

最后将获取的天数和$sum和指定$month的指定日$day的天数相加即可。我们来看看完整代码:

<?php
header("Content-type:text/html;charset=utf-8");
$year=2000;
$month=3;
$day=5;
//求一个月的最大天数
function GetMaxDay($year,$month){
$time = strtotime("{$year}-{$month}"); //取得一个日期的 Unix 时间戳;
$date=date("t",$time);
return $date;
}
//求总天数
//求之前几个月的天数
$sum=0;
for($i=1;$i<$month;$i++){
$sum += GetMaxDay($year,$i);
}
$sum = $sum + $day; //加上本月的天数,就是总天数
//求总天数
echo "截止 $year 年 $month 月 $day 日, 一共有 $sum 天 ";
?>
输出结果:

4.png

好了,将求总天数的代码封装为一个功能函数:

<?php
header("Content-type:text/html;charset=utf-8");
//求一个月的最大天数
function GetMaxDay($year,$month){
$time = strtotime("{$year}-{$month}"); //取得一个日期的 Unix 时间戳;
$date=date("t",$time);
return $date;
}
//求总天数
function GetDays($year,$month,$day){
//求之前几个月的天数
$sum=0;
for($i=1;$i<$month;$i++){
$sum += GetMaxDay($year,$i);
}
$sum = $sum + $day; //加上本月的天数,就是总天数
//求总天数
echo "截止 $year 年 $month 月 $day 日, 一共有 $sum 天
";
}
?>
调用这个功能函数GetDays($year,$month,$day)

GetDays(2000,3,5);
GetDays(2001,3,5);
GetDays(2001,2,5);
我们来看看输出结果:

3.png

好了就说到这里了,有其他想知道的,可以点击这个哦。→ →php视频教程

以上就是怎么通过PHP实现给定年月日计算总天数的详细内容,更多请关注富贵论坛www.fgba.net其它相关文章!

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
【leetcode刷题】29.合并二叉树——Java版
⭐欢迎订阅《leetcode》专栏,每日一题,每天进步⭐ 递归就完事了。。 大一菜鸡艰难刷题中。。 ——leetcode此题热评
3 0
回顾篇之Java的插入排序
回顾篇之Java的插入排序
3 0
【leetcode刷题】31.旋转数组的最小数字——Java版
⭐欢迎订阅《leetcode》专栏,每日一题,每天进步⭐ 什么鬼题目呀,管你旋不旋转,直接输出最小值不就完了。。。 ——leetcode此题热评
4 0
【leetcode刷题】32.二进制中1的个数——Java版
⭐欢迎订阅《leetcode》专栏,每日一题,每天进步⭐ 把一个整数减去1,再和原整数做与运算,会把该整数最右边一个1变成0.那么一个整数的二进制有多少个1,就可以进行多少次这样的操作。 ——leetcode此题热评
3 0
【leetcode刷题】27.二叉树的直径——Java版
⭐欢迎订阅《leetcode》专栏,每日一题,每天进步⭐ 可以将二叉树的直径转换为:二叉树的每个节点的左右子树的高度和的最大值。 ——leetcode此题热评
4 0
【leetcode刷题】28.替换空格——Java版
⭐欢迎订阅《leetcode》专栏,每日一题,每天进步⭐ return s.replace(" ","%20"); ——leetcode此题热评
3 0
高可用架构设计(3) -电商商品详情页缓存背景及框架说明
高可用架构设计(3) -电商商品详情页缓存背景及框架说明
4 0
狂补计算机基础知识,让我上了瘾,想要尽快和同龄人拉开差距,必须这么干,才有戏!!!!
狂补计算机基础知识,让我上了瘾,想要尽快和同龄人拉开差距,必须这么干,才有戏!!!!
4 0
帮我妹一 jio 踹开了 C 语言的大门,从此学习的路上不再迷茫不再彷徨(史上最强 C语言学习路线)
帮我妹一 jio 踹开了 C 语言的大门,从此学习的路上不再迷茫不再彷徨(史上最强 C语言学习路线)
3 0
【leetcode刷题】30.青蛙跳台阶——Java版
⭐欢迎订阅《leetcode》专栏,每日一题,每天进步⭐ 0级台阶还有1种跳法?这是要在原地来个托马斯旋转吗? ——leetcode此题热评
3 0
+关注
507
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
文娱运维技术
立即下载
《SaaS模式云原生数据仓库应用场景实践》
立即下载
《看见新力量:二》电子书
立即下载