java 月份中两个日期之间的差异
Difference between two dates in month in java
有关计算月份的查询,但有一些条件。
使用 Joda 日期时间或日期实用程序。
Start Date : 01/01/2018
End Date : 31/12/2020
上述日期之间的总期间差异:36 months and 0 days
所以总计 month =36
Start Date : 01/01/2018
End Date : 02/01/2021
上述日期之间的总期间差异:36 months and 2 days
。
如果还有剩余天数,则考虑单月。
所以 total month 36+1= 37
Date issueDate1=03/06/2017;
Date dateTo1=02/06/2020;
int investmentPeriod = Months.monthsBetween(issueDate1, dateTo1).getMonths();
joda 上面的月份是 coming 35
这是错误的。
开始日期=23/06/2017;
结束日期=06/07/2017;
这里相差不到一个月。所以它被认为是一个月。
使用 Java Util Date 解决方案可能是这样的...
final Date start = Date.from(ZonedDateTime.of(2018, 1, 1, 0, 0, 0, 0, ZoneId.of("UTC")).toInstant());
final Date end = Date.from(ZonedDateTime.of(2021, 1, 2, 0, 0, 0, 0, ZoneId.of("UTC")).toInstant());
final Calendar startCal = new GregorianCalendar();
startCal.setTime(start);
final Calendar endCal = new GregorianCalendar();
endCal.setTime(end);
final int yearOffset = (endCal.get(Calendar.YEAR) - startCal.get(Calendar.YEAR)) * 12;
final int monthOffset = endCal.get(Calendar.MONTH) - startCal.get(Calendar.MONTH);
final int dayOffset = (endCal.get(Calendar.DAY_OF_MONTH) - startCal.get(Calendar.DAY_OF_MONTH)) > 0 ? 1 : 0;
final int offset = yearOffset + monthOffset + dayOffset;
(我使用 ZonedDateTime 构造日期,但您当然可以使用时间戳或其他任何东西)
在 Java 8 中,您可以使用 DateTimes 和 ChronoUnits 来实现这一目的。解决方案可能如下所示:
final ZonedDateTime start = ZonedDateTime.of(2018, 1, 1, 0, 0, 0, 0, ZoneId.of("UTC"));
final ZonedDateTime end = ZonedDateTime.of(2021, 1, 2, 0, 0, 0, 0, ZoneId.of("UTC"));
final long monthOffset = ChronoUnit.MONTHS.between(start, end);
final int dayOffset = (end.getDayOfMonth() - start.getDayOfMonth()) > 0 ? 1 : 0;
final long offset = monthOffset + dayOffset;
ZoneId defaultZoneId = ZoneId.systemDefault();
String issueDate1="01/01/2017";
Date issueDate2=new SimpleDateFormat("dd/MM/yyyy").parse(issueDate1);
String dateTo1="31/12/2018";
Date dateTo2=new SimpleDateFormat("dd/MM/yyyy").parse(dateTo1);
在这里年月日可以找到easily.This给出所有问题的答案。
Instant instant = issueDate2.toInstant();
LocalDate localDatestart = instant.atZone(defaultZoneId).toLocalDate();
Instant instant1 = dateTo2.toInstant();
LocalDate localDateend = instant1.atZone(defaultZoneId).toLocalDate().plusDays(1);
Period diff = Period.between(localDatestart, localDateend);
System.out.printf("\nDifference is %d years, %d months and %d days old\n\n",
diff.getYears(), diff.getMonths(), diff.getDays());
有关计算月份的查询,但有一些条件。 使用 Joda 日期时间或日期实用程序。
Start Date : 01/01/2018
End Date : 31/12/2020
上述日期之间的总期间差异:36 months and 0 days
所以总计 month =36
Start Date : 01/01/2018
End Date : 02/01/2021
上述日期之间的总期间差异:36 months and 2 days
。
如果还有剩余天数,则考虑单月。
所以 total month 36+1= 37
Date issueDate1=03/06/2017;
Date dateTo1=02/06/2020;
int investmentPeriod = Months.monthsBetween(issueDate1, dateTo1).getMonths();
joda 上面的月份是 coming 35
这是错误的。
开始日期=23/06/2017;
结束日期=06/07/2017;
这里相差不到一个月。所以它被认为是一个月。
使用 Java Util Date 解决方案可能是这样的...
final Date start = Date.from(ZonedDateTime.of(2018, 1, 1, 0, 0, 0, 0, ZoneId.of("UTC")).toInstant());
final Date end = Date.from(ZonedDateTime.of(2021, 1, 2, 0, 0, 0, 0, ZoneId.of("UTC")).toInstant());
final Calendar startCal = new GregorianCalendar();
startCal.setTime(start);
final Calendar endCal = new GregorianCalendar();
endCal.setTime(end);
final int yearOffset = (endCal.get(Calendar.YEAR) - startCal.get(Calendar.YEAR)) * 12;
final int monthOffset = endCal.get(Calendar.MONTH) - startCal.get(Calendar.MONTH);
final int dayOffset = (endCal.get(Calendar.DAY_OF_MONTH) - startCal.get(Calendar.DAY_OF_MONTH)) > 0 ? 1 : 0;
final int offset = yearOffset + monthOffset + dayOffset;
(我使用 ZonedDateTime 构造日期,但您当然可以使用时间戳或其他任何东西)
在 Java 8 中,您可以使用 DateTimes 和 ChronoUnits 来实现这一目的。解决方案可能如下所示:
final ZonedDateTime start = ZonedDateTime.of(2018, 1, 1, 0, 0, 0, 0, ZoneId.of("UTC"));
final ZonedDateTime end = ZonedDateTime.of(2021, 1, 2, 0, 0, 0, 0, ZoneId.of("UTC"));
final long monthOffset = ChronoUnit.MONTHS.between(start, end);
final int dayOffset = (end.getDayOfMonth() - start.getDayOfMonth()) > 0 ? 1 : 0;
final long offset = monthOffset + dayOffset;
ZoneId defaultZoneId = ZoneId.systemDefault();
String issueDate1="01/01/2017";
Date issueDate2=new SimpleDateFormat("dd/MM/yyyy").parse(issueDate1);
String dateTo1="31/12/2018";
Date dateTo2=new SimpleDateFormat("dd/MM/yyyy").parse(dateTo1);
在这里年月日可以找到easily.This给出所有问题的答案。
Instant instant = issueDate2.toInstant();
LocalDate localDatestart = instant.atZone(defaultZoneId).toLocalDate();
Instant instant1 = dateTo2.toInstant();
LocalDate localDateend = instant1.atZone(defaultZoneId).toLocalDate().plusDays(1);
Period diff = Period.between(localDatestart, localDateend);
System.out.printf("\nDifference is %d years, %d months and %d days old\n\n",
diff.getYears(), diff.getMonths(), diff.getDays());