You can simply sort the List from Date using a custom Comparator . The following example sorts the date by week of the year, and then by date, I donβt know if you want the second part, but this is a good demonstration ...
import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Calendar; import java.util.Collections; import java.util.Comparator; import java.util.Date; import java.util.List; public class Test { public static void main(String[] args) { try { SimpleDateFormat sdf = new SimpleDateFormat("MM/dd/yyyy"); List<Date> dates = new ArrayList<Date>(25); dates.add(sdf.parse("04/01/2015")); dates.add(sdf.parse("04/02/2015")); dates.add(sdf.parse("04/03/2015")); dates.add(sdf.parse("04/04/2015")); dates.add(sdf.parse("04/05/2015")); dates.add(sdf.parse("04/06/2015")); dates.add(sdf.parse("04/07/2015")); dates.add(sdf.parse("04/08/2015")); dates.add(sdf.parse("04/09/2015")); int week = 0; int woy = -1; Collections.sort(dates, new WeekComparator()); for (Date date : dates) { if (woy != getWeekOfYear(date)) { woy = getWeekOfYear(date); week++; System.out.println("Week " + week + ":"); } System.out.println(date); } } catch (ParseException exp) { exp.printStackTrace(); } } public static class WeekComparator implements Comparator<Date> { @Override public int compare(Date o1, Date o2) { int result = getWeekOfYear(o1) - getWeekOfYear(o2); if (result == 0) { result = o1.compareTo(o2); } return result; } } protected static int getWeekOfYear(Date date) { Calendar cal = Calendar.getInstance(); cal.setTime(date); return cal.get(Calendar.WEEK_OF_YEAR); } }
What are the exits
Week 1: Wed Apr 01 00:00:00 EST 2015 Thu Apr 02 00:00:00 EST 2015 Fri Apr 03 00:00:00 EST 2015 Sat Apr 04 00:00:00 EST 2015 Week 2: Sun Apr 05 00:00:00 EST 2015 Mon Apr 06 00:00:00 EST 2015 Tue Apr 07 00:00:00 EST 2015 Wed Apr 08 00:00:00 EST 2015 Thu Apr 09 00:00:00 EST 2015
Java 8 Time API
And just because I need practice ...
import java.text.SimpleDateFormat; import java.time.LocalDate; import java.time.format.DateTimeFormatter; import java.time.temporal.WeekFields; import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.List; import java.util.Locale; public class Test { public static void main(String[] args) { SimpleDateFormat sdf = new SimpleDateFormat("MM/dd/yyyy"); DateTimeFormatter dtf = DateTimeFormatter.ofPattern("MM/dd/yyyy"); List<LocalDate> dates = new ArrayList<LocalDate>(25); dates.add(LocalDate.parse("04/01/2015", dtf)); dates.add(LocalDate.parse("04/02/2015", dtf)); dates.add(LocalDate.parse("04/03/2015", dtf)); dates.add(LocalDate.parse("04/04/2015", dtf)); dates.add(LocalDate.parse("04/05/2015", dtf)); dates.add(LocalDate.parse("04/06/2015", dtf)); dates.add(LocalDate.parse("04/07/2015", dtf)); dates.add(LocalDate.parse("04/08/2015", dtf)); dates.add(LocalDate.parse("04/09/2015", dtf)); int week = 0; int woy = -1; Collections.sort(dates, new WeekComparator()); for (LocalDate date : dates) { if (woy != getWeekOfYear(date)) { woy = getWeekOfYear(date); week++; System.out.println("Week " + week + ":"); } System.out.println(date); } } public static class WeekComparator implements Comparator<LocalDate> { @Override public int compare(LocalDate o1, LocalDate o2) { int result = getWeekOfYear(o1) - getWeekOfYear(o2); if (result == 0) { result = o1.compareTo(o2); } return result; } } protected static int getWeekOfYear(LocalDate date) { WeekFields wf = WeekFields.of(Locale.getDefault()); return date.get(wf.weekOfYear()); } }
What are the exits
Week 1: 2015-04-01 2015-04-02 2015-04-03 2015-04-04 Week 2: 2015-04-05 2015-04-06 2015-04-07 2015-04-08 2015-04-09
In any case, you can match each of the dates in Map with a key for a week, but it is up to you
source share