在设计数据模型的时候需要用到年份+周数作为唯一索引,于是就需要判断一个日期是属于哪一年的第几周,本来问题很简单的,但是会涉及到跨年的问题,例如以周一作为一个星期的开始,那么2018-12-30日星期日,属于2018年的第52周,而2018-12-31日星期一,就属于2019年的第1周,因此,只用一个日期属于第几周来判断是会有问题的,下面这个方法里面返回了年份与第几周,可以满足要求。
public static Map<String,Integer> getWeekAndYear(String date) {
Map<String,Integer> result = new HashMap<String,Integer>();
Calendar cal = Calendar.getInstance();
--设置一周的开始,默认是周日,这里设置成星期一
cal.setFirstDayOfWeek(Calendar.MONDAY);
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
SimpleDateFormat formatMon = new SimpleDateFormat("MM");
SimpleDateFormat formatYear = new SimpleDateFormat("yyyy");
Date d = null;
try {
d = format.parse(date);
} catch (ParseException e) {
e.printStackTrace();
}
cal.setTime(d);
int month = Integer.valueOf(formatMon.format(d));
int year = Integer.valueOf(formatYear.format(d));
int week = cal.get(Calendar.WEEK_OF_YEAR);
result.put("week", week);
if(week == 1 && month == 12){
result.put("year", year + 1);
}else{
result.put("year", year);
}
return result;
}