java 根据开始和结束时间分割出使用天数和每天使用的时间
需求,现在有一个跨天使用的东西,我需要计算出他每天使用了多少时间
时间段实体:
import lombok.Data; import java.text.SimpleDateFormat; import java.util.Date; /** * 时间段 */ @Data public class DateRange { private Date begin; //开始时间 private Date end; //结束时间 //只是为了方便查看,实际开发中不要这个鬼 public String toString(){ return "{" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(begin) +" ," + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(end) +"}"; } }
计算方法,两种方法都行
/** * 按小时计算,分隔 * * @param begin * @param end * @return */ public static List<DateRange> splitDateRangeByHour(Date begin, Date end) { System.out.println("按小时切割"); Calendar calendar = Calendar.getInstance(); calendar.setTime(begin); List<DateRange> list = Lists.newArrayList(); DateRange range = new DateRange(); range.setBegin(begin); while (true) { calendar.add(Calendar.HOUR_OF_DAY, 1); if (calendar.getTime().after(end)) { range.setEnd(end); list.add(range); break; } if (calendar.get(Calendar.HOUR_OF_DAY) == 23) { calendar.set(Calendar.MINUTE, 59); calendar.set(Calendar.SECOND, 59); calendar.set(Calendar.MILLISECOND, 0); range.setEnd(calendar.getTime()); list.add(range); //第二天时间计算,并创建新的时间段 calendar.add(Calendar.SECOND, 1); range = new DateRange(); range.setBegin(calendar.getTime()); continue; } } return list; } /** * 按天计算分隔(效率高 ,只超过一天有问题) * * @param begin * @param end * @return */ public static List<DateRange> splitDateRangeByDay(Date begin, Date end) { System.out.println("按天切割"); long time = end.getTime() - begin.getTime(); if (time == 0) { return Lists.newArrayList(); } long hours = time / (60 * 60 * 1000); if (time % (60 * 60 * 1000) > 0) { hours += 1; } if (hours <= 24) { return splitDateRangeByHour(begin, end); } Calendar calendar = Calendar.getInstance(); calendar.setTime(begin); List<DateRange> list = Lists.newArrayList(); DateRange range = new DateRange(); range.setBegin(begin); while (true) { calendar.add(Calendar.DAY_OF_YEAR, 1); if (calendar.getTime().after(end)) { range.setEnd(end); list.add(range); break; } calendar.set(Calendar.HOUR_OF_DAY, 0); calendar.set(Calendar.MINUTE, 0); calendar.set(Calendar.SECOND, 0); calendar.set(Calendar.MILLISECOND, 0); //今天的开始 Date tmpBeginTime = calendar.getTime(); //计算出上一天的最后一秒 calendar.add(Calendar.SECOND, -1); range.setEnd(calendar.getTime()); list.add(range); //创建新的时间段 range = new DateRange(); range.setBegin(tmpBeginTime); //回到今天 calendar.add(Calendar.SECOND, +1); } return list; }
测试和结果
//按天 public static void main(String[] args) throws ParseException { Date begin = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").parse("2019-02-27 08:00:12"); Date end = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").parse("2019-03-03 12:01:08"); List<DateRange> dateRanges = splitDateRangeByDay(begin, end); System.out.println(dateRanges); } 输出 2019-02-28 08:00:12 2019-03-01 00:00:00 2019-03-02 00:00:00 2019-03-03 00:00:00 2019-03-04 00:00:00 1111 [{2019-02-27 08:00:12 ,2019-02-27 23:59:59}, {2019-02-28 00:00:00 ,2019-02-28 23:59:59}, {2019-03-01 00:00:00 ,2019-03-01 23:59:59}, {2019-03-02 00:00:00 ,2019-03-02 23:59:59}, {2019-03-03 00:00:00 ,2019-03-03 12:01:08}] //按小时 public static void main(String[] args) throws ParseException { Date begin = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").parse("2019-02-27 08:00:12"); Date end = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").parse("2019-03-03 12:01:08"); List<DateRange> dateRanges = splitDateRangeByHour(begin, end); System.out.println(dateRanges); } 输出 2019-02-27 09:00:12 2019-02-27 10:00:12 2019-02-27 11:00:12 2019-02-27 12:00:12 2019-02-27 13:00:12 2019-02-27 14:00:12 2019-02-27 15:00:12 2019-02-27 16:00:12 2019-02-27 17:00:12 2019-02-27 18:00:12 2019-02-27 19:00:12 2019-02-27 20:00:12 2019-02-27 21:00:12 2019-02-27 22:00:12 2019-02-27 23:00:12 2019-02-28 01:00:00 2019-02-28 02:00:00 2019-02-28 03:00:00 2019-02-28 04:00:00 2019-02-28 05:00:00 2019-02-28 06:00:00 2019-02-28 07:00:00 2019-02-28 08:00:00 2019-02-28 09:00:00 2019-02-28 10:00:00 2019-02-28 11:00:00 2019-02-28 12:00:00 2019-02-28 13:00:00 2019-02-28 14:00:00 2019-02-28 15:00:00 2019-02-28 16:00:00 2019-02-28 17:00:00 2019-02-28 18:00:00 2019-02-28 19:00:00 2019-02-28 20:00:00 2019-02-28 21:00:00 2019-02-28 22:00:00 2019-02-28 23:00:00 2019-03-01 01:00:00 2019-03-01 02:00:00 2019-03-01 03:00:00 2019-03-01 04:00:00 2019-03-01 05:00:00 2019-03-01 06:00:00 2019-03-01 07:00:00 2019-03-01 08:00:00 2019-03-01 09:00:00 2019-03-01 10:00:00 2019-03-01 11:00:00 2019-03-01 12:00:00 2019-03-01 13:00:00 2019-03-01 14:00:00 2019-03-01 15:00:00 2019-03-01 16:00:00 2019-03-01 17:00:00 2019-03-01 18:00:00 2019-03-01 19:00:00 2019-03-01 20:00:00 2019-03-01 21:00:00 2019-03-01 22:00:00 2019-03-01 23:00:00 2019-03-02 01:00:00 2019-03-02 02:00:00 2019-03-02 03:00:00 2019-03-02 04:00:00 2019-03-02 05:00:00 2019-03-02 06:00:00 2019-03-02 07:00:00 2019-03-02 08:00:00 2019-03-02 09:00:00 2019-03-02 10:00:00 2019-03-02 11:00:00 2019-03-02 12:00:00 2019-03-02 13:00:00 2019-03-02 14:00:00 2019-03-02 15:00:00 2019-03-02 16:00:00 2019-03-02 17:00:00 2019-03-02 18:00:00 2019-03-02 19:00:00 2019-03-02 20:00:00 2019-03-02 21:00:00 2019-03-02 22:00:00 2019-03-02 23:00:00 2019-03-03 01:00:00 2019-03-03 02:00:00 2019-03-03 03:00:00 2019-03-03 04:00:00 2019-03-03 05:00:00 2019-03-03 06:00:00 2019-03-03 07:00:00 2019-03-03 08:00:00 2019-03-03 09:00:00 2019-03-03 10:00:00 2019-03-03 11:00:00 2019-03-03 12:00:00 2019-03-03 13:00:00 1111 [{2019-02-27 08:00:12 ,2019-02-27 23:59:59}, {2019-02-28 00:00:00 ,2019-02-28 23:59:59}, {2019-03-01 00:00:00 ,2019-03-01 23:59:59}, {2019-03-02 00:00:00 ,2019-03-02 23:59:59}, {2019-03-03 00:00:00 ,2019-03-03 12:01:08}]
posted on 2020-04-18 01:22 Steven5007 阅读(1686) 评论(0) 编辑 收藏 举报