JAVA计算某个日期时间段属于当年第几周且返回周一和周日

由于之前自己没怎么接触过如此的计算,一时感觉有些迷茫,直到网上查询了点资料做参考,我这个方法 ,主要是用于计算某个时间段属于某年 第几周 及返回当前周的周一 和周日日期。比如说: 要计算2020-01-03~2010-03-09之间的日期,且把每天应该属于第几周按周分割开来,可以使用我这个方法。
在这里插入图片描述

/**
	     * 获取某个时间属于本年第几周及返回周一和周日
	     */
	    
		public static PageData getweek(String mydata) {
			Integer week = null;
			PageData dateData = new PageData();
			try {

				Calendar cal = Calendar.getInstance();
				SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); 
				Calendar calendar = Calendar.getInstance();
				calendar.setFirstDayOfWeek(Calendar.MONDAY);
				Date time = sdf.parse(mydata);
				cal.setTime(time);

				// 判断要计算的日期是否是周日,如果是则减一天计算周六的,否则会出问题,计算到下一周去了
				int dayWeek = cal.get(Calendar.DAY_OF_WEEK);// 获得当前日期是一个星期的第几天
				if (1 == dayWeek) {
					cal.add(Calendar.DAY_OF_MONTH, -1);
				}
				cal.setFirstDayOfWeek(Calendar.MONDAY);// 设置一个星期的第一天
				int day = cal.get(Calendar.DAY_OF_WEEK);// 获得当前日期是一个星期的第几天
				cal.add(Calendar.DATE, cal.getFirstDayOfWeek() - day);// 根据日历的规则,给当前日期减去星期几与一个星期第一天的差值
				System.out.println("所在周星期一的日期:" + sdf.format(cal.getTime()));
				
				dateData.put("weekstart",  sdf.format(cal.getTime()));
				
				String date1 = sdf.format(cal.getTime());
				Date time1 = sdf.parse(date1);
				calendar.setTime(time1);
				int week1 = calendar.get(Calendar.WEEK_OF_YEAR);

			//	System.out.println(cal.getFirstDayOfWeek() + "-" + day + "+6=" + (cal.getFirstDayOfWeek() - day + 6));

				cal.add(Calendar.DATE, 6);
				System.out.println("所在周星期日的日期:" + sdf.format(cal.getTime()));

				String date2 = sdf.format(cal.getTime());
				Date time2 = sdf.parse(date2);
				calendar.setTime(time2);
				int week2 = calendar.get(Calendar.WEEK_OF_YEAR);
				week = (week1 >= week2 ? week2 : week1);
				dateData.put("week", week);
				dateData.put("weekend", sdf.format(cal.getTime()));
				
			} catch (Exception e) {
				
				throw new RuntimeException(e);
			}

			return dateData;
		}





		/**
		 * 获取 本年是第几周 格式:2020-01-22~2020-01-26  jsonarray返回
		 * @param st   开始时间:2020-01-03
		 * @param et  结束时间:2020-03-08
		 * @return  jsonArray格式 阿里的
		 */
		public static JSONArray findTimes(String st, String et) {
			JSONArray res = new JSONArray();
			Calendar cal = Calendar.getInstance();
			int year = cal.get(Calendar.YEAR);
			SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
			Date finalEndDate = null;
			try {
				if (null != st && ! "".equals(st))) {  //
					st = sdf.format(new Date());
				}
				if (null != et && ! "".equals(et))) {
					finalEndDate = sdf.parse(et);
				} else {
					cal.clear();
					cal.set(Calendar.YEAR, year);
					cal.roll(Calendar.DAY_OF_YEAR, -1);
					finalEndDate = cal.getTime();
					et = sdf.format(finalEndDate); //结束日期
				}
				/**获取解析的本年第几周和周开始和结束日期**/ 
				boolean flag = true;
				while (flag) {  //循环遍历每一周,直到日期结束
					JSONObject jo = new JSONObject();
					Date std = sdf.parse(st);
					cal.setTime(std);
					PageData weekData = null;
					weekData = Tools.getweek(st);
					String weekCount = weekData.getString("week"); // 本年第几周
					String endtime = weekData.getString("weekend"); // 当前周 周日 日期
					//String weekstart = weekData.getString("weekstart"); // 当前周 周一 日期
					String weekend=endtime;
					
					jo.put("starttime", sdf.format(std)); // 开始日期
					for (int i = 0; i < 7; i++) {
						cal.add(Calendar.DAY_OF_MONTH, 1); // 天数加一
						Date etd = cal.getTime();
						String formatend = sdf.format(etd);
						if (etd.after(finalEndDate)) {
							endtime=et;
							flag = false;
							break;
						}
						endtime = sdf.format(etd);
						if(endtime.equals(weekend)){
							break;
						}
					}

					if (!"".equals(endtime)) {
						cal.add(Calendar.DAY_OF_MONTH, 1);
						st = sdf.format(cal.getTime());
						jo.put("endtime", endtime);
						jo.put("weeks", jo.getString("starttime") + "~" + endtime);
						jo.put("weeksDate", "第" + weekCount + "周");
						res.add(jo);  //这里封装每一个周的数据
					}
					
				}
			} catch (Exception e) {
				e.printStackTrace();
			}
			return res;
		}
		
//这里解释一下 类PageData我们项目里面封装的,实现与hashMap,可以用hashMap来替换。
							欢迎大家提意见!!!
								202.03.10
							 writed by sir.du
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值