可能重复:
获取给定月份的工作日数
如何计算任何一个月的工作日?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()获取月份的物理名称,然后使用switch或if来确定它是否是工作日。
$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!
$myTime=strtotime('+1 day', $myTime);
而不是仅仅添加 86,400 秒,因为我注意到在某些情况下,添加一天的秒数并不能始终产生一致的结果。 - Aaron Mason直接在谷歌上搜索就好了,伙计。
为了后人,你的算法:
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