可能重复:
获取给定月份的工作日数
如何计算任何一个月的工作日?cal_days_in_month
仅返回一个月中的总天数。我的任务是计算每个月的天数,除了周六和周日或仅周日。有什么方法可以找到这个吗?
可能重复:
获取给定月份的工作日数
如何计算任何一个月的工作日?cal_days_in_month
仅返回一个月中的总天数。我的任务是计算每个月的天数,除了周六和周日或仅周日。有什么方法可以找到这个吗?
function countDays($year, $month, $ignore) {
$count = 0;
$counter = mktime(0, 0, 0, $month, 1, $year);
while (date("n", $counter) == $month) {
if (in_array(date("w", $counter), $ignore) == false) {
$count++;
}
$counter = strtotime("+1 day", $counter);
}
return $count;
}
echo countDays(2013, 1, array(0, 6)); // 23
本例中使用了该date
函数。关于忽略参数的注意事项:0 是星期日,...,6 是星期六。
复制第二个答案:获取给定月份的工作日数
你不需要计算每个月的每一天。您已经知道前 28 天无论如何都包含 20 个工作日。您所要做的就是确定最后几天。将起始值更改为 29。然后将 20 个工作日添加到您的返回值。
function get_weekdays($m,$y) {
$lastday = date("t",mktime(0,0,0,$m,1,$y));
$weekdays=0;
for($d=29;$d<=$lastday;$d++) {
$wd = date("w",mktime(0,0,0,$m,$d,$y));
if($wd > 0 && $wd < 6) $weekdays++;
}
return $weekdays+20;
}
这应该可以解决您的问题,并且确实是一个有效的解决方案。
一个简单(不那么优雅)的答案就是创建该月第一天的时间戳,使用 date() 获取月份的物理名称,然后切换或确定它是否是工作日.
$myTime = strtotime("1/1/2013"); // Use whatever date format you want
$daysInMonth = cal_days_in_month(CAL_GREGORIAN, 1, 2013); // 31
$workDays = 0;
while($daysInMonth > 0)
{
$day = date("D", $myTime); // Sun - Sat
if($day != "Sun" && $day != "Sat")
$workDays++;
$daysInMonth--;
$myTime += 86400; // 86,400 seconds = 24 hrs.
}
echo "There are $workDays work days this month!";
输出
There are 23 work days this month!
做一个谷歌搜索,伙计。
对于后代,您的算法:
function countDays($y, $m, $ignore = false)
{
$result = 0;
$loop = strtotime("$y-$m-01");
do if(!$ignore or !in_array(strftime("%u",$loop),$ignore))
$result++;
while(strftime("%m",$loop = strtotime("+1 day",$loop))==$m);
return $result;
}
echo countDays(2013,1,array(6,7));//23
echo countDays(2013,2);//28