java преобразование миллисекунд в формат времени
Я пытаюсь преобразовать длинное целое значение (количество миллисекунд, прошедших с 1/1/1970) в формате h:m:s:ms
Длинное значение, которое я использую в качестве метки времени, я получаю из поля timestamp события регистрации из log4j.
Как мне сделать преобразование?
Например, чтобы получить минуты, я попробовал следующее, И все не получилось:
logEvent.метки/ (1000*60*60) и
TimeUnit.МИЛЛИСЕКУНДЫ.toMinutes(действие logevent.отметка времени)
но я получаю мусор:
Я получаю
1289375173771 for logEvent.timeStamp
358159 for logEvent.timeStamp/ (1000*60*60)
21489586 for TimeUnit.MILLISECONDS.toMinutes(logEvent.timeStamp)
как я могу преобразовать это?
спасибо
8 ответов:
попробуйте это:
Date date = new Date(logEvent.timeSTamp); DateFormat formatter = new SimpleDateFormat("HH:mm:ss.SSS"); formatter.setTimeZone(TimeZone.getTimeZone("UTC")); String dateFormatted = formatter.format(date);посмотреть SimpleDateFormat для описания других строк формата, которые принимает класс.
посмотреть выполнимое пример используя входной сигнал 1200 МС.
long millis = durationInMillis % 1000; long second = (durationInMillis / 1000) % 60; long minute = (durationInMillis / (1000 * 60)) % 60; long hour = (durationInMillis / (1000 * 60 * 60)) % 24; String time = String.format("%02d:%02d:%02d.%d", hour, minute, second, millis);
Я покажу вам три способа (а) получить поле минут из длинного значения и (Б) распечатать его с использованием формата даты, который вы хотите. Один использует java.утиль.Календарь, другой использует Joda Времени, и последний использует java.временные рамки, встроенные в Java 8 и выше.
java.временная структура заменяет старые связанные классы даты-времени и вдохновляется Joda-Time, определенным JSR 310, и расширяется проектом ThreeTen-Extra.
java.время фреймворк-это способ использования Java 8 и более поздних версий. В противном случае, например, Android, используйте Joda-Time. Ява.утиль.Дата./Календарные классы, как известно, хлопотно и следует избегать.
java.утиль.Дата. & Календарь
final long timestamp = new Date().getTime(); // with java.util.Date/Calendar api final Calendar cal = Calendar.getInstance(); cal.setTimeInMillis(timestamp); // here's how to get the minutes final int minutes = cal.get(Calendar.MINUTE); // and here's how to get the String representation final String timeString = new SimpleDateFormat("HH:mm:ss:SSS").format(cal.getTime()); System.out.println(minutes); System.out.println(timeString);Joda Времени
// with JodaTime 2.4 final DateTime dt = new DateTime(timestamp); // here's how to get the minutes final int minutes2 = dt.getMinuteOfHour(); // and here's how to get the String representation final String timeString2 = dt.toString("HH:mm:ss:SSS"); System.out.println(minutes2); System.out.println(timeString2);выход:
24
09:24:10:254
24
09:24:10:254java.время
long millisecondsSinceEpoch = 1289375173771L; Instant instant = Instant.ofEpochMilli ( millisecondsSinceEpoch ); ZonedDateTime zdt = ZonedDateTime.ofInstant ( instant , ZoneOffset.UTC ); DateTimeFormatter formatter = DateTimeFormatter.ofPattern ( "HH:mm:ss:SSS" ); String output = formatter.format ( zdt ); System.out.println ( "millisecondsSinceEpoch: " + millisecondsSinceEpoch + " instant: " + instant + " output: " + output );миллисекунды: 1289375173771 мгновение: 2010-11-10T07: 46: 13.771 Z выход: 07:46:13:771
можно использовать apache commons (commons-lang3) и его класс DurationFormatUtils.
<dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-lang3</artifactId> <version>3.1</version> </dependency>например:
String formattedDuration = DurationFormatUtils.formatDurationHMS(12313152); // formattedDuration value is "3:25:13.152" String otherFormattedDuration = DurationFormatUtils.formatDuration(12313152, DurationFormatUtils.ISO_EXTENDED_FORMAT_PATTERN); // otherFormattedDuration value is "P0000Y0M0DT3H25M13.152S"надеюсь, что это может помочь ...
long second = TimeUnit.MILLISECONDS.toSeconds(millis); long minute = TimeUnit.MILLISECONDS.toMinutes(millis); long hour = TimeUnit.MILLISECONDS.toHours(millis); millis -= TimeUnit.SECONDS.toMillis(second); return String.format("%02d:%02d:%02d:%d", hour, minute, second, millis);
public static String timeDifference(long timeDifference1) { long timeDifference = timeDifference1/1000; int h = (int) (timeDifference / (3600)); int m = (int) ((timeDifference - (h * 3600)) / 60); int s = (int) (timeDifference - (h * 3600) - m * 60); return String.format("%02d:%02d:%02d", h,m,s);
попробуйте это:
String sMillis = "10997195233"; double dMillis = 0; int days = 0; int hours = 0; int minutes = 0; int seconds = 0; int millis = 0; String sTime; try { dMillis = Double.parseDouble(sMillis); } catch (Exception e) { System.out.println(e.getMessage()); } seconds = (int)(dMillis / 1000) % 60; millis = (int)(dMillis % 1000); if (seconds > 0) { minutes = (int)(dMillis / 1000 / 60) % 60; if (minutes > 0) { hours = (int)(dMillis / 1000 / 60 / 60) % 24; if (hours > 0) { days = (int)(dMillis / 1000 / 60 / 60 / 24); if (days > 0) { sTime = days + " days " + hours + " hours " + minutes + " min " + seconds + " sec " + millis + " millisec"; } else { sTime = hours + " hours " + minutes + " min " + seconds + " sec " + millis + " millisec"; } } else { sTime = minutes + " min " + seconds + " sec " + millis + " millisec"; } } else { sTime = seconds + " sec " + millis + " millisec"; } } else { sTime = dMillis + " millisec"; } System.out.println("time: " + sTime);
делаешь
logEvent.timeStamp / (1000*60*60)даст вам часы, а не минуты. Попробуйте:
logEvent.timeStamp / (1000*60)и вы получите тот же ответ, что и
TimeUnit.MILLISECONDS.toMinutes(logEvent.timeStamp)
Comments