날짜에서 주 번호 (연도) 가져 오기 PHP
나는 데이트를하고 그 주 번호를 계산하고 싶다.
지금까지 다음이 있습니다. 42가 될 때 24를 반환합니다.
<?php
$ddate = "2012-10-18";
$duedt = explode("-",$ddate);
$date = mktime(0, 0, 0, $duedt[2], $duedt[1],$duedt[0]);
$week = (int)date('W', $date);
echo "Weeknummer: ".$week;
?>
숫자가 반대로 된 것이 잘못입니까? 아니면 거의 다 왔나요?
오늘날, PHP의 DateTime
객체를 사용하는 것이 더 좋습니다.
<?php
$ddate = "2012-10-18";
$date = new DateTime($ddate);
$week = $date->format("W");
echo "Weeknummer: $week";
mktime()
에서는 다음과 같이 진행 되기 때문입니다 .
mktime(hour, minute, second, month, day, year);
따라서 주문이 잘못되었습니다.
<?php
$ddate = "2012-10-18";
$duedt = explode("-", $ddate);
$date = mktime(0, 0, 0, $duedt[1], $duedt[2], $duedt[0]);
$week = (int)date('W', $date);
echo "Weeknummer: " . $week;
?>
$date_string = "2012-10-18";
echo "Weeknummer: " . date("W", strtotime($date_string));
PHP의 날짜 기능 사용
http://php.net/manual/en/function.date.php
date("W", $yourdate)
제안으로 :
<?php echo date("W", strtotime("2012-10-18")); ?>
그 모든 것보다 조금 더 간단 할 수 있습니다.
수행 할 수있는 기타 작업 :
<?php echo date("Weeknumber: W", strtotime("2012-10-18 01:00:00")); ?>
<?php echo date("Weeknumber: W", strtotime($MY_DATE)); ?>
이것은 오늘 날짜를 얻은 다음 그주의 주 번호를 알려줍니다.
<?php
$date=date("W");
echo $date." Week Number";
?>
<?php
$ddate = "2012-10-18";
$duedt = explode("-",$ddate);
$date = mktime(0, 0, 0, $duedt[1], $duedt[2],$duedt[0]);
$week = (int)date('W', $date);
echo "Weeknummer: ".$week;
?>
mktime에 대한 매개 변수가 잘못되었습니다. 일 / 월 / 년이 아닌 월 / 일 / 년이어야합니다.
북미에서 날짜의 주 번호를 얻으려면 다음과 같이합니다.
function week_number($n)
{
$w = date('w', $n);
return 1 + date('z', $n + (6 - $w) * 24 * 3600) / 7;
}
$n = strtotime('2022-12-27');
printf("%s: %d\n", date('D Y-m-d', $n), week_number($n));
그리고 얻다:
Tue 2022-12-27: 53
코드는 작동하지만 4 번째와 5 번째 인수를 뒤집어 야합니다.
나는 이렇게 할 것이다
$date_string = "2012-10-18";
$date_int = strtotime($date_string);
$date_date = date($date_int);
$week_number = date('W', $date_date);
echo "Weeknumber: {$week_number}.";
또한 해당 코드를 보지 않고 일주일 후에 변수 이름이 혼란 스러울 것입니다. http://net.tutsplus.com/tutorials/php/why-youre-a-bad-php-programmer/를 읽어보십시오.
규칙은 한 해의 첫 번째 주가 해당 연도의 첫 번째 목요일을 포함하는 주라는 것입니다.
저는 개인적으로 이런 종류의 계산에 Zend_Date를 사용하고 있으며 오늘의 주를 얻는 것은 간단합니다. 날짜로 작업하는 경우 다른 유용한 기능이 많이 있습니다.
$now = Zend_Date::now();
$week = $now->get(Zend_Date::WEEK);
// 10
이 해결책을 시도하십시오
date( 'W', strtotime( "2017-01-01 + 1 day" ) );
나는 수년 동안이 질문을 풀려고 노력했지만 더 짧은 해결책을 찾았지만 다시 긴 이야기로 돌아와야한다고 생각했습니다. 이 함수는 올바른 ISO 주 표기법을 제공합니다.
/**
* calcweek("2018-12-31") => 1901
* This function calculates the production weeknumber according to the start on
* monday and with at least 4 days in the new year. Given that the $date has
* the following format Y-m-d then the outcome is and integer.
*
* @author M.S.B. Bachus
*
* @param date-notation PHP "Y-m-d" showing the data as yyyy-mm-dd
* @return integer
**/
function calcweek($date) {
// 1. Convert input to $year, $month, $day
$dateset = strtotime($date);
$year = date("Y", $dateset);
$month = date("m", $dateset);
$day = date("d", $dateset);
$referenceday = getdate(mktime(0,0,0, $month, $day, $year));
$jan1day = getdate(mktime(0,0,0,1,1,$referenceday[year]));
// 2. check if $year is a leapyear
if ( ($year%4==0 && $year%100!=0) || $year%400==0) {
$leapyear = true;
} else {
$leapyear = false;
}
// 3. check if $year-1 is a leapyear
if ( (($year-1)%4==0 && ($year-1)%100!=0) || ($year-1)%400==0 ) {
$leapyearprev = true;
} else {
$leapyearprev = false;
}
// 4. find the dayofyearnumber for y m d
$mnth = array(0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334);
$dayofyearnumber = $day + $mnth[$month-1];
if ( $leapyear && $month > 2 ) { $dayofyearnumber++; }
// 5. find the jan1weekday for y (monday=1, sunday=7)
$yy = ($year-1)%100;
$c = ($year-1) - $yy;
$g = $yy + intval($yy/4);
$jan1weekday = 1+((((intval($c/100)%4)*5)+$g)%7);
// 6. find the weekday for y m d
$h = $dayofyearnumber + ($jan1weekday-1);
$weekday = 1+(($h-1)%7);
// 7. find if y m d falls in yearnumber y-1, weeknumber 52 or 53
$foundweeknum = false;
if ( $dayofyearnumber <= (8-$jan1weekday) && $jan1weekday > 4 ) {
$yearnumber = $year - 1;
if ( $jan1weekday = 5 || ( $jan1weekday = 6 && $leapyearprev )) {
$weeknumber = 53;
} else {
$weeknumber = 52;
}
$foundweeknum = true;
} else {
$yearnumber = $year;
}
// 8. find if y m d falls in yearnumber y+1, weeknumber 1
if ( $yearnumber == $year && !$foundweeknum) {
if ( $leapyear ) {
$i = 366;
} else {
$i = 365;
}
if ( ($i - $dayofyearnumber) < (4 - $weekday) ) {
$yearnumber = $year + 1;
$weeknumber = 1;
$foundweeknum = true;
}
}
// 9. find if y m d falls in yearnumber y, weeknumber 1 through 53
if ( $yearnumber == $year && !$foundweeknum ) {
$j = $dayofyearnumber + (7 - $weekday) + ($jan1weekday - 1);
$weeknumber = intval( $j/7 );
if ( $jan1weekday > 4 ) { $weeknumber--; }
}
// 10. output iso week number (YYWW)
return ($yearnumber-2000)*100+$weeknumber;
}
I found out that my short solution missed the 2018-12-31 as it gave back 1801 instead of 1901. So I had to put in this long version which is correct.
To get Correct Week Count for Date 2018-12-31 Please use below Code
$day_count = date('N',strtotime('2018-12-31'));
$week_count = date('W',strtotime('2018-12-31'));
if($week_count=='01' && date('m',strtotime('2018-12-31'))==12){
$yr_count = date('y',strtotime('2018-12-31')) + 1;
}else{
$yr_count = date('y',strtotime('2018-12-31'));
}
function last_monday($date)
{
if (!is_numeric($date))
$date = strtotime($date);
if (date('w', $date) == 1)
return $date;
else
return date('Y-m-d',strtotime('last monday',$date));
}
$date = '2021-01-04'; //Enter custom date
$year = date('Y',strtotime($date));
$date1 = new DateTime($date);
$ldate = last_monday($year."-01-01");
$date2 = new DateTime($ldate);
$diff = $date2->diff($date1)->format("%a");
$diff = $diff/7;
$week = intval($diff) + 1;
echo $week;
//Returns 2.
참고URL : https://stackoverflow.com/questions/9567673/get-week-number-in-the-year-from-a-date-php
'programing tip' 카테고리의 다른 글
Ruby와 Ruby on Rails의 차이점은 무엇입니까? (0) | 2020.11.30 |
---|---|
닫기 명령을 단추에 바인딩하는 방법 (0) | 2020.11.29 |
Swagger UI Web Api 문서 열거 형을 문자열로 표시합니까? (0) | 2020.11.29 |
색상 이름을 16 진수 코드로 변환하는 자바 스크립트 함수 (0) | 2020.11.29 |
오류 : Objective-C 모듈 'Firebase'를 빌드 할 수 없습니다. (0) | 2020.11.29 |