如何找出给定日期和开始和结束时间可用的所有持续时间:java

Posted

技术标签:

【中文标题】如何找出给定日期和开始和结束时间可用的所有持续时间:java【英文标题】:how to find out all the time duration available for given date and start and end time : java 【发布时间】:2015-05-18 06:54:51 【问题描述】:

我有日期和时间格式为开始日期和时间15-05-15 02:00:AM 结束日期和时间15-05-15 06:00:AM. with the time interval of60 分钟`

我如何找出这两个日期和时间之间的可用时间?

结果是

start Time : 15-05-15 02:00:AM end Time : 15-05-15 03:00:AM
start Time : 15-05-15 03:00:AM end Time : 15-05-15 04:00:AM
start Time : 15-05-15 05:00:AM end Time : 15-05-15 06:00:AM

如果开始日期时间和结束日期时间范围在第二天范围内,请帮我处理。

我正在使用java 7

谢谢

【问题讨论】:

【参考方案1】:

Java 8

LocalDateTime#parse 开头,将String 值解析为LocalDateTime

然后使用循环,使用 plusMinutes 递增“开始”LocalDateTime 的值,直到值为 equalisAfter,然后是“结束”LocalDateTime

String startAt = "15-05-15 02:00:AM";
String endAt = "15-05-15 06:00:AM";

String format = "dd-MM-yy hh:mm':'a";

LocalDateTime startTime = LocalDateTime.parse(startAt, DateTimeFormatter.ofPattern(format));
LocalDateTime endTime = LocalDateTime.parse(endAt, DateTimeFormatter.ofPattern(format));
while (endTime.isAfter(startTime)) 
    LocalDateTime next = startTime.plusMinutes(60);
    System.out.println("StartTime : " + startTime.format(DateTimeFormatter.ofPattern(format)) + "; End Time : " + next.format(DateTimeFormatter.ofPattern(format)));
    startTime = next;

打印出来的...

StartTime : 15-05-15 02:00:AM; End Time : 15-05-15 03:00:AM
StartTime : 15-05-15 03:00:AM; End Time : 15-05-15 04:00:AM
StartTime : 15-05-15 04:00:AM; End Time : 15-05-15 05:00:AM
StartTime : 15-05-15 05:00:AM; End Time : 15-05-15 06:00:AM

Joda-Time(其他所有人)

String startAt = "15-05-15 02:00:AM";
String endAt = "15-05-15 06:00:AM";

String format = "dd-MM-yy hh:mm':'a";
DateTimeFormatter formatter = DateTimeFormat.forPattern(format);

LocalDateTime startTime = formatter.parseLocalDateTime(startAt);
LocalDateTime endTime = formatter.parseLocalDateTime(endAt);

while (endTime.isAfter(startTime)) 
    LocalDateTime next = startTime.plusMinutes(60);
    System.out.println("StartTime : " + formatter.print(startTime) + "; End Time : " + formatter.print(next));
    startTime = next;

打印出来的

StartTime : 15-05-15 02:00:AM; End Time : 15-05-15 03:00:AM
StartTime : 15-05-15 03:00:AM; End Time : 15-05-15 04:00:AM
StartTime : 15-05-15 04:00:AM; End Time : 15-05-15 05:00:AM
StartTime : 15-05-15 05:00:AM; End Time : 15-05-15 06:00:AM

“我不允许使用第三方库”(不推荐的方法)

try 
    String startAt = "15-05-15 02:00:AM";
    String endAt = "15-05-15 06:00:AM";

    String format = "dd-MM-yy hh:mm':'a";
    SimpleDateFormat sdf = new SimpleDateFormat(format);
    Date startDate = sdf.parse(startAt);
    Date endDate = sdf.parse(endAt);

    Calendar startCal = Calendar.getInstance();
    startCal.setTime(startDate);
    Calendar endCal = Calendar.getInstance();
    endCal.setTime(endDate);

    while (endCal.after(startCal)) 

        String start = sdf.format(startCal.getTime());
        startCal.add(Calendar.MINUTE, 60);
        String to = sdf.format(startCal.getTime());

        System.out.println("Start Time : " + start + "; End Time : " + to);

    

 catch (ParseException exp) 
    exp.printStackTrace();

哪些打印...

Start Time : 15-05-15 02:00:AM; End Time : 15-05-15 03:00:AM
Start Time : 15-05-15 03:00:AM; End Time : 15-05-15 04:00:AM
Start Time : 15-05-15 04:00:AM; End Time : 15-05-15 05:00:AM
Start Time : 15-05-15 05:00:AM; End Time : 15-05-15 06:00:AM

【讨论】:

为什么不用 Duration 类? @MadProgrammer 感谢您的回答,您能帮我在 java 7 中做同样的事情吗? 我们不能使用 DurationInstance.getSeconds();然后我们可以应用逻辑将其转换为适当的格式。 嗯 .. 感谢您的解释。我只是想知道那也是另一种方式,对吧? @BilboBaggins 只是简单地认为这适用于 ;)。我可能遗漏了一些东西,但是使用Duration,您仍然需要从 A 点到 A 点的时间 + 60 秒...不是吗?【参考方案2】:
java.util.Date startDate;
java.util.Date endDate;
java.util.Date currDate = startDate;

while (currDate < endDate) 
    Calendar cal = new GregorianCalendar();
    cal.setTime(currDate);
    cal.add(Calendar.HOUR_OF_DAY, 1);

    System.out.println("StartTime : " + startTime.format(DateTimeFormatter.ofPattern(format)) + "; End Time : " + cal.getTime().format(DateTimeFormatter.ofPattern(format)));
    currDate = cal.getTime();

【讨论】:

以上是关于如何找出给定日期和开始和结束时间可用的所有持续时间:java的主要内容,如果未能解决你的问题,请参考以下文章

如何根据 PL/pgSQL 中的开始日期和持续时间(工作日)获取结束日期?

如何总结时间,不包括Oracle中给定的开始日期时间和结束日期时间的重叠时间

CakePHP 在 2 个日期记录之间搜索

获取给定周年、给定月份和给定周的开始和结束日期

给定日期范围(开始日期和结束日期),我如何计算天数,不包括 .Net 中指定的星期几?

如何在Algolia中搜索持续时间