public static Map<String, List<String>> getWeekAndYearList(LocalDate startTime, LocalDate endTime) {
Map map = new HashMap();
List<String> resultList = new ArrayList<String>();
List<String> yearList = new ArrayList<String>();
DateTimeFormatter df = DateTimeFormatter.ofPattern("yyyy-MM-dd");
//判断是否同一周
WeekFields weekFields = WeekFields.of(DayOfWeek.MONDAY, 4);
if (startTime.get(weekFields.weekOfWeekBasedYear()) == endTime.get(weekFields.weekOfWeekBasedYear())) {
int week = getWeekIntBydate(df.format(startTime));
int year = getYearByDate(df.format(startTime));
resultList.add("WK" + (week - 9 > 0 ? week : "0" + week));
yearList.add(year + "WK" + (week - 9 > 0 ? week : "0" + week));
map.put("resultList", resultList);
map.put("yearList", yearList);
return map;
}
//开始周
TemporalAdjuster FIRST_OF_WEEK = TemporalAdjusters.ofDateAdjuster(localDate -> localDate.minusDays(localDate.getDayOfWeek().getValue() - DayOfWeek.MONDAY.getValue()));
LocalDate startFirstWeek = startTime.with(FIRST_OF_WEEK); //开始周开始日期
TemporalAdjuster LAST_OF_WEEK = TemporalAdjusters.ofDateAdjuster(localDate -> localDate.plusDays(DayOfWeek.SUNDAY.getValue() - localDate.getDayOfWeek().getValue()));
LocalDate endFirstWeek = startTime.with(LAST_OF_WEEK); //开始周结束日期
//结束周
TemporalAdjuster FIRST_OF_WEEK1 = TemporalAdjusters.ofDateAdjuster(localDate -> localDate.minusDays(localDate.getDayOfWeek().getValue() - DayOfWeek.MONDAY.getValue()));
LocalDate startLastWeek = endTime.with(FIRST_OF_WEEK1);
TemporalAdjuster LAST_OF_WEEK1 = TemporalAdjusters.ofDateAdjuster(localDate -> localDate.plusDays(DayOfWeek.SUNDAY.getValue() - localDate.getDayOfWeek().getValue()));
LocalDate endLastWeek = endTime.with(LAST_OF_WEEK1);
//将第一周添加
int week = getWeekIntBydate(df.format(startFirstWeek));
int year = getYearByDate(df.format(startFirstWeek));
resultList.add("WK" + (week > 9 ? week : "0" + week));
yearList.add(year + "WK" + (week > 9 ? week : "0" + week));
while (true) {
startFirstWeek = startFirstWeek.plusDays(7);
if (startFirstWeek.with(LAST_OF_WEEK).equals(startLastWeek.with(LAST_OF_WEEK1))) {
break;
} else {
int week1 = getWeekIntBydate(df.format(startFirstWeek.with(FIRST_OF_WEEK)));
int year1 = getYearByDate(df.format(startFirstWeek.with(FIRST_OF_WEEK)));
resultList.add("WK" + (week1 > 9 ? week1 : "0" + week1));
yearList.add(year1 + "WK" + (week1 > 9 ? week1 : "0" + week1));
}
}
int week2 = getWeekIntBydate(df.format(startLastWeek));
int year2 = getYearByDate(df.format(startLastWeek));
resultList.add("WK" + (week2 > 9 ? week2 : "0" + week2));
yearList.add(year2 + "WK" + (week2 > 9 ? week2 : "0" + week2));
map.put("resultList", resultList);
map.put("yearList", yearList);
return map;
}