Golang의 주 번호별 날짜 범위
주 번호 불일치 해결
시간. Go 표준 라이브러리의 ISOWeek() 함수는 월요일에 시작하는 ISO 주 번호를 반환합니다. 그러나 일요일 시작 날짜를 기준으로 한 주 번호가 필요한 것으로 보입니다.
사용자 정의 유틸리티
이 문제를 해결하려면 사용자 정의 유틸리티 기능을 활용하여 원하는 기간:
import "time" func WeekStart(year, week int) time.Time { // Align to first day of the week (Sunday) and correct week number t := time.Date(year, time.July, 1, 0, 0, 0, 0, time.UTC) if wd := t.Weekday(); wd == time.Sunday { t = t.AddDate(0, 0, -6) } else { t = t.AddDate(0, 0, -int(wd)+1) } t = t.AddDate(0, 0, (week-1)*7) return t }
주 범위
지정된 주의 시작 날짜와 종료 날짜가 모두 필요한 경우 다음 기능을 사용할 수 있습니다.
func WeekRange(year, week int) (start, end time.Time) { start = WeekStart(year, week) end = start.AddDate(0, 0, 6) return }
샘플 출력
fmt.Println(WeekRange(2018, 1)) fmt.Println(WeekRange(2018, 52))
출력
2018-01-01 00:00:00 +0000 UTC 2018-01-07 00:00:00 +0000 UTC 2018-12-24 00:00:00 +0000 UTC 2018-12-30 00:00:00 +0000 UTC
참고: 이 방법은 0을 다음과 같이 해석하여 범위를 벗어난 주를 처리합니다. 전년도 마지막 주, 전년도 두 번째에서 마지막 주로 -1 등입니다.
위 내용은 Go에서 주 번호를 기준으로 날짜 범위를 얻는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!