获取一年中按星期归类(星期一、星期二...)所有日期

本文介绍了一个Java方法,用于根据当前日期获取一年中每一天的具体日期,并将这些日期按星期进行分类。通过使用`Calendar`和`DateFormatSymbols`类,该方法能够有效地区分不同星期并收集对应的日期。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >



public static Map<String,List<Date>> getDatesByWeek(){
 
    Calendar c_begin = new GregorianCalendar();
    Calendar c_end = new GregorianCalendar();
    DateFormatSymbols dfs = new DateFormatSymbols();
    String[] weeks = dfs.getWeekdays();
    int year = DateUtil.getYear();
    int month = DateUtil.getMonth();
    int day = DateUtil.getToDayOfMonth();
    c_begin.set(year, month, day); //Calendar的月从0-11,
    c_end.set(year, 11, 31); //Calendar的月从0-11,
    List<Date> scheduledDates=new ArrayList<Date>();
    Map<String,List<Date>> map = new HashMap<String, List<Date>>();
    int count = 1;
    c_end.add(Calendar.DAY_OF_YEAR, 1);  //结束日期下滚一天是为了包含最后一天
    
    while(c_begin.before(c_end)){
//       System.out.println("第"+count+"周  日期:"+new java.sql.Date(c_begin.getTime().getTime())+","+weeks[c_begin.get(Calendar.DAY_OF_WEEK)]);
      String DAY_OF_WEEK=weeks[c_begin.get(Calendar.DAY_OF_WEEK)];
      
      Date date = c_begin.getTime();
      if(!map.containsKey(DAY_OF_WEEK)){
      map.put(DAY_OF_WEEK, new ArrayList<Date>());
      }
      map.get(DAY_OF_WEEK).add(date);
      
      if(c_begin.get(Calendar.DAY_OF_WEEK)==Calendar.SUNDAY){
      count++;
      }
     c_begin.add(Calendar.DAY_OF_YEAR, 1);
    }
  return map;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值