仅工作日并删除 PHP 中的周末和节假日
Only working days and remove weekend and holidays in PHP
我正在尝试仅设置工作日的格式,删除周六、周日和节假日。
我在我的祖国 "Whosebug" 假期里找到了这个功能 "function day_holiday()"。
据我所知,我在下面的 php 中创建了这个脚本
//-------------------------HOLIDAY--------------
function day_holiday($ano = null){
if ($ano === null){
$ano = intval(date('Y'));
}
$pascoa = easter_date($ano);
$dia_pascoa = date('j', $pascoa);
$mes_pascoa = date('n', $pascoa);
$ano_pascoa = date('Y', $pascoa);
$holiday = array(
mktime(0, 0, 0, 1, 1, $ano),
mktime(0, 0, 0, 4, 21, $ano),
mktime(0, 0, 0, 5, 1, $ano),
mktime(0, 0, 0, 9, 7, $ano),
mktime(0, 0, 0, 10, 12, $ano),
mktime(0, 0, 0, 11, 2, $ano),
mktime(0, 0, 0, 11, 15, $ano),
mktime(0, 0, 0, 12, 25, $ano),
mktime(0, 0, 0, $mes_pascoa, $dia_pascoa - 48, $ano_pascoa),
mktime(0, 0, 0, $mes_pascoa, $dia_pascoa - 47, $ano_pascoa),
mktime(0, 0, 0, $mes_pascoa, $dia_pascoa - 2 , $ano_pascoa),
mktime(0, 0, 0, $mes_pascoa, $dia_pascoa , $ano_pascoa),
mktime(0, 0, 0, $mes_pascoa, $dia_pascoa + 60, $ano_pascoa),
);
sort($holiday);
return $holiday;
}
//-------------------------HOLIDAY--------------
//-------------SCRIPT-------------
function formatDate($startDate,$days) {
$holiday = day_holiday();
foreach ($holiday as $allholiday){
if($startDate==date('d-m-Y',$allholiday)){
$newDate=date('d-m-Y', strtotime("+1 days",strtotime($startDate)));
}else{
$newDate = date('d-m-Y', strtotime("{$startDate} +{$days} weekdays"));
}
}
return $newDate;
}
$sales = "19-01-2019"; //19 and Saturday is jumping for Monday 21 second
/*
These are some holidays.
01-01-2019
04-03-2019
05-03-2019
19-04-2019
21-04-2019
21-04-2019
01-05-2019
*/
echo "Start: ",date("d-m-Y", strtotime($sales)),"<br />";
echo formatDate($sales, "0");
问题是只在周六和周日移除。假期没有被删除。什么不见了?有人能帮我吗?如果您有更动态的脚本,您可以在此处post。
这可能是一种更强大的方式来做你想做的事。该函数从开始时间创建一个 DateTime
对象,然后比较时间戳以查看是否
- 在
$holiday
数组中;或
- 星期六或星期日(星期几 = 0 或 6)
如果这些条件中的 none 为真,则循环退出并返回日期。否则,日期增加 1 天,直到找到符合所有条件的日期(即周一至周五,而不是节假日)。
function formatDate($startDate) {
$holiday = day_holiday();
$start = date_create_from_format('d-m-Y H:i:s', $startDate . ' 00:00:00');
do {
$ts = (int)$start->format('U');
$dow = (int)$start->format('w');
if (!in_array($ts, $holiday) && $dow != 0 && $dow != 6) break;
$start->modify('+1 day');
}
while (true);
return $start->format('d-m-Y');
}
我正在尝试仅设置工作日的格式,删除周六、周日和节假日。
我在我的祖国 "Whosebug" 假期里找到了这个功能 "function day_holiday()"。
据我所知,我在下面的 php 中创建了这个脚本
//-------------------------HOLIDAY--------------
function day_holiday($ano = null){
if ($ano === null){
$ano = intval(date('Y'));
}
$pascoa = easter_date($ano);
$dia_pascoa = date('j', $pascoa);
$mes_pascoa = date('n', $pascoa);
$ano_pascoa = date('Y', $pascoa);
$holiday = array(
mktime(0, 0, 0, 1, 1, $ano),
mktime(0, 0, 0, 4, 21, $ano),
mktime(0, 0, 0, 5, 1, $ano),
mktime(0, 0, 0, 9, 7, $ano),
mktime(0, 0, 0, 10, 12, $ano),
mktime(0, 0, 0, 11, 2, $ano),
mktime(0, 0, 0, 11, 15, $ano),
mktime(0, 0, 0, 12, 25, $ano),
mktime(0, 0, 0, $mes_pascoa, $dia_pascoa - 48, $ano_pascoa),
mktime(0, 0, 0, $mes_pascoa, $dia_pascoa - 47, $ano_pascoa),
mktime(0, 0, 0, $mes_pascoa, $dia_pascoa - 2 , $ano_pascoa),
mktime(0, 0, 0, $mes_pascoa, $dia_pascoa , $ano_pascoa),
mktime(0, 0, 0, $mes_pascoa, $dia_pascoa + 60, $ano_pascoa),
);
sort($holiday);
return $holiday;
}
//-------------------------HOLIDAY--------------
//-------------SCRIPT-------------
function formatDate($startDate,$days) {
$holiday = day_holiday();
foreach ($holiday as $allholiday){
if($startDate==date('d-m-Y',$allholiday)){
$newDate=date('d-m-Y', strtotime("+1 days",strtotime($startDate)));
}else{
$newDate = date('d-m-Y', strtotime("{$startDate} +{$days} weekdays"));
}
}
return $newDate;
}
$sales = "19-01-2019"; //19 and Saturday is jumping for Monday 21 second
/*
These are some holidays.
01-01-2019
04-03-2019
05-03-2019
19-04-2019
21-04-2019
21-04-2019
01-05-2019
*/
echo "Start: ",date("d-m-Y", strtotime($sales)),"<br />";
echo formatDate($sales, "0");
问题是只在周六和周日移除。假期没有被删除。什么不见了?有人能帮我吗?如果您有更动态的脚本,您可以在此处post。
这可能是一种更强大的方式来做你想做的事。该函数从开始时间创建一个 DateTime
对象,然后比较时间戳以查看是否
- 在
$holiday
数组中;或 - 星期六或星期日(星期几 = 0 或 6)
如果这些条件中的 none 为真,则循环退出并返回日期。否则,日期增加 1 天,直到找到符合所有条件的日期(即周一至周五,而不是节假日)。
function formatDate($startDate) {
$holiday = day_holiday();
$start = date_create_from_format('d-m-Y H:i:s', $startDate . ' 00:00:00');
do {
$ts = (int)$start->format('U');
$dow = (int)$start->format('w');
if (!in_array($ts, $holiday) && $dow != 0 && $dow != 6) break;
$start->modify('+1 day');
}
while (true);
return $start->format('d-m-Y');
}