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)


как я могу преобразовать это?



спасибо

962   8  

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:254

java.время

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

    Ничего не найдено.