誰かがPHP=スニペットを使用して、特定の日付の翌営業日を計算しますか?たとえば、YYYY-MM-DDを次の営業日を見つけるにはどのように変換する必要がありますか?
例:2011年4月3日(DD-MM-YYYY)の場合、翌営業日は2011年4月4日です。 2011年4月8日の場合、翌営業日は2011年4月11日です。
これは、翌営業日を知る必要がある日付を含む変数です
$cubeTime['time'];
変数に含まれるもの:2011-04-01スニペットの結果は次のとおりです:2011-04-04
翌平日
これは、特定の日付(土曜日または日曜日を含まない)から次の平日を検索します。
echo date('Y-m-d', strtotime('2011-04-05 +1 Weekday'));
もちろん、日付変数を使用してそれを行うこともできます:
$myDate = '2011-04-05';
echo date('Y-m-d', strtotime($myDate . ' +1 Weekday'));
UPDATE:または、 PHPのDateTimeクラスにアクセスできる場合 (可能性が高い):
$date = new DateTime('2018-01-27');
$date->modify('+7 weekday');
echo $date->format('Y-m-d');
祝日をスキップしますか?:
元のポスターには「休日を考慮する必要はない」と書いてありましたが、もし休日を無視したい場合は、覚えておいてください-「休日」は、含めたくない日付の配列であり、国によって異なります、地域、会社、人...など.
上記のコードを、含めたくない日付を過ぎて除外/ループする関数に単に入れてください。このようなもの:
$tmpDate = '2015-06-22';
$holidays = ['2015-07-04', '2015-10-31', '2015-12-25'];
$i = 1;
$nextBusinessDay = date('Y-m-d', strtotime($tmpDate . ' +' . $i . ' Weekday'));
while (in_array($nextBusinessDay, $holidays)) {
$i++;
$nextBusinessDay = date('Y-m-d', strtotime($tmpDate . ' +' . $i . ' Weekday'));
}
上記のコードは、必要に応じて簡略化または短縮できると思います。わかりやすく書いてみました。
英国の休日には、
https://www.gov.uk/bank-holidays#england-and-wales
ICS形式データは解析が簡単です。私の提案は...
# $date must be in YYYY-MM-DD format
# You can pass in either an array of holidays in YYYYMMDD format
# OR a URL for a .ics file containing holidays
# this defaults to the UK government holiday data for England and Wales
function addBusinessDays($date,$numDays=1,$holidays='') {
if ($holidays==='') $holidays = 'https://www.gov.uk/bank-holidays/england-and-wales.ics';
if (!is_array($holidays)) {
$ch = curl_init($holidays);
curl_setopt($ch,CURLOPT_RETURNTRANSFER,true);
$ics = curl_exec($ch);
curl_close($ch);
$ics = explode("\n",$ics);
$ics = preg_grep('/^DTSTART;/',$ics);
$holidays = preg_replace('/^DTSTART;VALUE=DATE:(\\d{4})(\\d{2})(\\d{2}).*/s','$1-$2-$3',$ics);
}
$addDay = 0;
while ($numDays--) {
while (true) {
$addDay++;
$newDate = date('Y-m-d', strtotime("$date +$addDay Days"));
$newDayOfWeek = date('w', strtotime($newDate));
if ( $newDayOfWeek>0 && $newDayOfWeek<6 && !in_array($newDate,$holidays)) break;
}
}
return $newDate;
}
あなたがする必要があるのは:
指定された日付をタイムスタンプに変換します。
これをPHPの date コマンドのor w
またはN
フォーマッターと一緒に使用して、曜日を通知します。
「営業日」ではない場合は、タイムスタンプを1日(86400秒)増やして、営業日になるまで再度確認できます。
注:これは本当にの作業なので、銀行や祝日なども除外する必要があります。
function next_business_day($date) {
$add_day = 0;
do {
$add_day++;
$new_date = date('Y-m-d', strtotime("$date +$add_day Days"));
$new_day_of_week = date('w', strtotime($new_date));
} while($new_day_of_week == 6 || $new_day_of_week == 0);
return $new_date;
}
この関数は週末を無視する必要があります(6 =土曜日と0 =日曜日)。
この関数は、未来または過去の営業日を計算します。引数は、日数、前方(1)または後方(0)、および日付です。日付が指定されていない場合、今日の日付が使用されます。
// returned $date Y/m/d
function work_days_from_date($days, $forward, $date=NULL)
{
if(!$date)
{
$date = date('Y-m-d'); // if no date given, use todays date
}
while ($days != 0)
{
$forward == 1 ? $day = strtotime($date.' +1 day') : $day = strtotime($date.' -1 day');
$date = date('Y-m-d',$day);
if( date('N', strtotime($date)) <= 5) // if it's a weekday
{
$days--;
}
}
return $date;
}
「次の日の配達」をコーディングする必要があるデンマークのWebサイトで作業しているときに、このスレッドにつまずきましたPHPスクリプト。
これは私が思いついたものです(これはデンマーク語での次の就業日の名前、および現在の時間が所定の制限を超えている場合は次の就業+1)を表示します)
$day["Mon"] = "Mandag";
$day["Tue"] = "Tirsdag";
$day["Wed"] = "Onsdag";
$day["Thu"] = "Torsdag";
$day["Fri"] = "Fredag";
$day["Sat"] = "Lørdag";
$day["Sun"] = "Søndag";
date_default_timezone_set('Europe/Copenhagen');
$date = date('l');
$checkTime = '1400';
$date2 = date(strtotime($date.' +1 Weekday'));
if( date( 'Hi' ) >= $checkTime) {
$date2 = date(strtotime($date.' +2 Weekday'));
}
if (date('l') == 'Saturday'){
$date2 = date(strtotime($date.' +2 Weekday'));
}
if (date('l') == 'Sunday') {
$date2 = date(strtotime($date.' +2 Weekday'));
}
echo '<p>Næste levering: <span>'.$day[date("D", $date2)].'</span></p>';
サンプルコードで確認できるように、$ checkTimeは、翌日配達が+1営業日か+2営業日かを決定する時間制限を設定する場所です。
「1400」= 14:00時間
Ifステートメントをより圧縮できることは知っていますが、コードを表示して、動作を簡単に理解できるようにします。
誰かがこの小さなスニペットを使用できることを願っています。
以下の例をご覧ください。
$startDate = new DateTime( '2013-04-01' ); //intialize start date
$endDate = new DateTime( '2013-04-30' ); //initialize end date
$holiday = array('2013-04-11','2013-04-25'); //this is assumed list of holiday
$interval = new DateInterval('P1D'); // set the interval as 1 day
$daterange = new DatePeriod($startDate, $interval ,$endDate);
foreach($daterange as $date){
if($date->format("N") <6 AND !in_array($date->format("Y-m-d"),$holiday))
$result[] = $date->format("Y-m-d");
}
echo "<pre>";print_r($result);
このようなことができます。
_/**
* @param string $date
* @param DateTimeZone|null|null $DateTimeZone
* @return \NavigableDate\NavigableDateInterface
*/
function getNextBusinessDay(string $date, ? DateTimeZone $DateTimeZone = null):\NavigableDate\NavigableDateInterface
{
$Date = \NavigableDate\NavigableDateFacade::create($date, $DateTimeZone);
$NextDay = $Date->nextDay();
while(true)
{
$nextDayIndexInTheWeek = (int) $NextDay->format('N');
// check if the day is between Monday and Friday. In DateTime class php, Monday is 1 and Friday is 5
if ($nextDayIndexInTheWeek >= 1 && $nextDayIndexInTheWeek <= 5)
{
break;
}
$NextDay = $NextDay->nextDay();
}
return $NextDay;
}
$date = '2017-02-24';
$NextBussinessDay = getNextBusinessDay($date);
var_dump($NextBussinessDay->format('Y-m-d'));
_
出力:
_string(10) "2017-02-27"
_
\NavigableDate\NavigableDateFacade::create($date, $DateTimeZone)
、 https://packagist.org/packages/ishworkh/navigable-date にあるphpライブラリによって提供されます。まず、このライブラリをcomposerまたは直接ダウンロードして、プロジェクトに含める必要があります。