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
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章