java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > java计算指定日期为本年第几周

java计算指定日期为本年第几周的实例

作者:品种

本文介绍了在编程中按周统计数据时遇到的问题,由于mysql中按所在月的周数周统计比较麻烦,采用所在年的周数作为分组条件,并通过java计算日期属于年的第一周来进行二次计算,提高性能,同时,作者也分享了计算指定日期为本年第几周的方法,并指出了一些常见方法的缺陷

编程中经常遇到日期计算,由于项目中使用到按周统计数据,但是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().get(field) + 1;
    }
    return week;
}

java8以下版本使用Calendar

public static int getWeekOfYear(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 && calendar.get(Calendar.MONTH) == Calendar.DECEMBER) {
        calendar.add(Calendar.DAY_OF_MONTH, -7);
        return calendar.get(Calendar.WEEK_OF_YEAR) + 1;
    }
    return week;
}

以周日为每周第一天为例,运行结果如下

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文