2 つの間の差を計算しようとしていますLocalDateTime
。
出力は の形式にする必要がありますy years m months d days h hours m minutes s seconds
。私が書いた内容は次のとおりです。
import java.time.Duration;
import java.time.Instant;
import java.time.LocalDateTime;
import java.time.Period;
import java.time.ZoneId;
public class Main {
static final int MINUTES_PER_HOUR = 60;
static final int SECONDS_PER_MINUTE = 60;
static final int SECONDS_PER_HOUR = SECONDS_PER_MINUTE * MINUTES_PER_HOUR;
public static void main(String[] args) {
LocalDateTime toDateTime = LocalDateTime.of(2014, 9, 9, 19, 46, 45);
LocalDateTime fromDateTime = LocalDateTime.of(1984, 12, 16, 7, 45, 55);
Period period = getPeriod(fromDateTime, toDateTime);
long time[] = getTime(fromDateTime, toDateTime);
System.out.println(period.getYears() + " years " +
period.getMonths() + " months " +
period.getDays() + " days " +
time[0] + " hours " +
time[1] + " minutes " +
time[2] + " seconds.");
}
private static Period getPeriod(LocalDateTime dob, LocalDateTime now) {
return Period.between(dob.toLocalDate(), now.toLocalDate());
}
private static long[] getTime(LocalDateTime dob, LocalDateTime now) {
LocalDateTime today = LocalDateTime.of(now.getYear(),
now.getMonthValue(), now.getDayOfMonth(), dob.getHour(), dob.getMinute(), dob.getSecond());
Duration duration = Duration.between(today, now);
long seconds = duration.getSeconds();
long hours = seconds / SECONDS_PER_HOUR;
long minutes = ((seconds % SECONDS_PER_HOUR) / SECONDS_PER_MINUTE);
long secs = (seconds % SECONDS_PER_MINUTE);
return new long[]{hours, minutes, secs};
}
}
私が得ている出力は です29 years 8 months 24 days 12 hours 0 minutes 50 seconds
。私はこれの結果を確認しましたWebサイト(値12/16/1984 07:45:55
および09/09/2014 19:46:45
)。次のスクリーンショットは出力を示しています。
月の値の後のフィールドが私のコードでは間違っていることはほぼ確実です。 何かアドバイスがあれば大変助かります。
アップデート
別の Web サイトで結果をテストしたところ、異なる結果が返されました。次のようになります。2つの日付間の期間を計算する(結果:29年8ヶ月24日12時間0分50秒)。
アップデート
2 つの異なるサイトから 2 つの異なる結果が得られたので、計算のアルゴリズムが正当かどうか疑問に思っています。次の 2 つのLocalDateTime
オブジェクトを使用する場合:
LocalDateTime toDateTime = LocalDateTime.of(2014, 9, 10, 6, 40, 45);
LocalDateTime fromDateTime = LocalDateTime.of(1984, 12, 16, 7, 45, 55);
すると、出力は次のようになります:29 years 8 months 25 days -1 hours -5 minutes -10 seconds.
これからリンクそうであるべきです29 years 8 months 24 days 22 hours, 54 minutes and 50 seconds
。したがって、アルゴリズムは負の数も処理する必要があります。
質問はどのサイトがどのような結果を出したかではなく、正しいアルゴリズムを知り、正しい結果を得る必要があることに注意してください。
ベストアンサー1
これを行う最良の方法はChronoUnit を使用することだとわかりました。
long minutes = ChronoUnit.MINUTES.between(fromDate, toDate);
long hours = ChronoUnit.HOURS.between(fromDate, toDate);
追加のドキュメントはここにあります:期間と期間