根据开始日期和截止日期,按年,周,当天返回的结果:
Calendar类的成员方法 static Calendar getInstance() 使用默认时区和区域设置获取日历。通过该方法生成Calendar对象。如下所示:Calendar cr=Calendar.getInstance(); public void set(int year,int month,int date,int hourofday,int minute,int second) 设置日历的年、月、日、时、分、秒。 public int get(int field) 返回给定日历字段的值。所谓字段就是年、月、日等等。 public void setTime(Date date) 使用给定的Date设置此日历的时间。Date------Calendar public Date getTime() 返回一个Date表示此日历的时间。Calendar-----Date abstract void add(int field,int amount) 按照日历的规则,给指定字段添加或减少时间量。 public long getTimeInMillies() 以毫秒为单位返回该日历的时间值。
查询 DAY_OF_WEEK,,周一是2,周日是1
时间单位字段 YEAR 年 MINUTE 分 DAY_OF_WEEK_IN_MONTH 某月中的第几周 MONTH 月 SECOND/MILLISECOND 秒/毫秒 WEEK_OF_MONTH 日历的第几周 DATE 日 DAY_OF_MONTH 和Date一样 DAY_OF_YEAR 一年的第多少天 HOUR_OF_DAY 时 DAY_OF_WEEK 周几 WEEK_OF_YEAR 一年的第多少周
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.Date;
import java.util.List;
import java.util.stream.Collectors;
public class DateRange {
// 格式化年月日时分秒
public static String DATE_YYYY_MM_DD_HH_MM_SS = "yyyy-MM-dd HH:mm:ss";
public static String DATE_YYYY_MM = "yyyy-MM-dd";
public static List getNextWeekDateList(String startDate, String endDate) throws ParseException {
List<String> dateList = new ArrayList<>();
List<String> list = new ArrayList<>();
//格式化格式
SimpleDateFormat sdf = new SimpleDateFormat(DATE_YYYY_MM_DD_HH_MM_SS);
SimpleDateFormat sdf1 = new SimpleDateFormat(DATE_YYYY_MM);
//将string类型转换成Date类型
Calendar start = Calendar.getInstance();
Date startDate1 = sdf.parse(startDate);
start.setTime(startDate1);
Calendar end = Calendar.getInstance();
Date endDate1 = sdf.parse(endDate);
end.setTime(endDate1);
//计算两日期间相差天数
long time = (endDate1.getTime() - startDate1.getTime()) / 1000 / 3600 / 24;
for (int i = 0; i <= time; i++) {
//创建calendar实例
Calendar start1 = Calendar.getInstance();
start1.setTime(startDate1);
start1.add(Calendar.DAY_OF_MONTH, i);
//将时分秒清空
start1.set(Calendar.HOUR_OF_DAY, 00);
start1.set(Calendar.MINUTE, 00);
start1.set(Calendar.SECOND, 00);
//存入起始时间
if (i == 0){
start1.setTimeInMillis(start.getTimeInMillis());
}
dateList.add(sdf.format(start1.getTime()));
//创建终止时间
Calendar end1 = Calendar.getInstance();
end1.setTime(start1.getTime());
//终止时间时分秒清零
end1.set(Calendar.HOUR_OF_DAY, 23);
end1.set(Calendar.MINUTE, 59);
end1.set(Calendar.SECOND, 59);
//存入终止时间
if (i == time){
end1.setTimeInMillis(end.getTimeInMillis());
}
dateList.add(sdf.format(end1.getTime()));
}
for (int i = 0; i<dateList.size(); i++){
Calendar calendar = Calendar.getInstance();
calendar.setTime(sdf.parse(dateList.get(i)));
Calendar calendar2 = Calendar.getInstance();
//判断当前时间年是否与下一个年份不一致
if (i + 1 != dateList.size()){
calendar2.setTime(sdf.parse(dateList.get(i+1)));
if (calendar.get(Calendar.YEAR) != calendar2.get(Calendar.YEAR)){
list.add(dateList.get(i));
list.add(dateList.get(i+1));
}
}
//存起始时间
list.add(dateList.get(0));
//判断是否为本周周一,判断起始时间和截止时间是否在同一天,判断前一个数是否与第二个数相等,相等则留下
//周一是2
if (i > dateList.size() -14 && calendar.get(Calendar.DAY_OF_WEEK) == 2 && i+1!=dateList.size() && sdf1.parse(dateList.get(i)).equals(sdf1.parse(dateList.get(i+1)))){
//判断周一是否是起始时间,不是则存入周一前一天
if (i-1>=0){
list.add(dateList.get(i-1));
}
list.add(dateList.get(i));
}
//当天日期+前一天日期
if (i == dateList.size() -2 || i == dateList.size() -1 || i == dateList.size() -3){
list.add(dateList.get(i));
}
}
List<String> myList = list.stream().distinct().collect(Collectors.toList());
List<DateInfo> list1 = new ArrayList<>();
System.out.println(myList.size());
for (int i = 0; i < myList.size() - 1; i++) {
list1.add(new DateInfo(myList.get(i), myList.get(i + 1)));
i++;
}
return list1;
}
调用:
public static void main(String[] args) throws ParseException {
List<DateInfo> list = DateRange.getNextWeekDateList("2022-12-09 12:12:12","2023-01-12 21:12:12");
for (DateInfo l : list){
System.out.println(l);
}
}
结果:
//结果集
DateInfo(startDate=2022-12-09 12:12:12, endDate=2022-12-31 23:59:59)
DateInfo(startDate=2023-01-01 00:00:00, endDate=2023-01-08 23:59:59)
DateInfo(startDate=2023-01-09 00:00:00, endDate=2023-01-11 23:59:59)
DateInfo(startDate=2023-01-12 00:00:00, endDate=2023-01-12 21:12:12)