java计算指定日期为本年第几周的实例
目录
- Java8及以上版本可以采用LocalDate/LocalDateTime
- java8以下版本使用Calendar
- 总结
编程中经常遇到日期计算,由于项目中使用到按周统计数据,但是mysql中按所在月的周数周统计比较麻烦,于是采用所在年的周数作为分组条件,再通过java计算日期属于年的第一周来进行二次计算,提高性能。
找了下计算指定日期为本年第几周的方法,发现没有现成的API,但网上给出的方法大部分都有个缺陷:
若12月31日是 周最后一天(有的以周一为每周的第一天,有的以周日为周的第一天),则计算正常,否则所在周会被计算为下一年的第一周,于是做此记录。
java8及以上版本可以采用LocalDate/LocalDateTime
/** 获取当年的第几周,返回值范围为1-53 */
public static int getWeekOfYear(LocalDate date) {
TemporalField field = WeekFields.of(Locale.getDefault()).weekOfWeekBasedYear();
int week = date.get(field);
// 12-31会被计算为下一年的第1周,所以需要特殊处理
if (week == 1 && getLocalDate().getMonth() == Month.DECEMBER) {
return LocalDate.of(date.getYear(), 12,31)// 直接使用指定日期的12月31日作为锚点
.addDays(-7)// 往上推一周,一定是本年倒数第二周
.getLocalDate(http://www.devze.com).get(field) + 1;
}
return week;
}
java8以下版本使用Calendar
public static int getWeek编程客栈OfYear(Date date) {
Calendar calendar = Calendar.getInstance(Locale.getDefault());
calendar.setTime(date);
calendar.setFirstDayOfWeek(Calendar.SUNDAY); // 设置每周的第一天为星期日
int week = calendar.get(Calendar.WEEK_OF_YEAR);
if (week == 1 &phpamp;& calendar.get(Calendar.MONTH) == Calendar.DECEMBER) {
calendar.add(Calendar.DAY_OF_MONTH, -7);
return calendar.get(Calendar.WEEK_OF_Yhttp://www.devze.comEAR) + 1;
}
python return week;
}
以周日为每周第一天为例,运行结果如下

总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程客栈(www.devze.com)。
加载中,请稍侯......
精彩评论