밀리 초 단위의 타임 스탬프를 Java의 문자열 형식 시간으로 변환


126

긴 값 ( 1970 년 1 월 1 일에서 경과 한 밀리 초, 즉 Epoch )을 형식 시간으로 변환하려고 합니다 h:m:s:ms.

타임 스탬프로 사용하는 긴 값 timestamp은 log4j의 로깅 이벤트 필드에서 가져옵니다 .

지금까지 다음을 시도했지만 실패했습니다.

logEvent.timeStamp/ (1000*60*60)
TimeUnit.MILLISECONDS.toMinutes(logEvent.timeStamp)

하지만 잘못된 값을 얻습니다.

1289375173771 for logEvent.timeStamp
358159  for logEvent.timeStamp/ (1000*60*60) 
21489586 for TimeUnit.MILLISECONDS.toMinutes(logEvent.timeStamp)

어떻게해야합니까?

답변:


188

이 시도:

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 을 참조하십시오 .

1200ms 입력을 사용하는 실행 가능한 예 를 참조하십시오 .


8
설명 : HH는 1970 년 이후 총 경과 시간이 아니라 해당 날짜 (0-23)의 시간을 인쇄합니다.
JohnyTex

4
그리고 잊지 마세요. 이전 SimpleDateFormat은 다중 스레드로 사용할 수 없습니다.
keiki

가져 오려면 SimpleDateFormat다음과 같이 가져 오기 를 사용하십시오.import java.text.*;
Naveen Kumar RB

1
참고로, 같은 귀찮은 된 날짜 - 시간 수업 java.util.Date, java.util.Calendar그리고 java.text.SimpleDateFormat지금 기존 에 의해 대체, java.time의 나중에 자바 8에 내장 된 클래스. Oracle의 Tutorial 참조하십시오 . 참조 : stackoverflow.com/a/4142428/642706
Basil Bourque

1
logevent의 종류는 무엇입니까? 질문에 넣어 주시겠습니까?
Raulp

127
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);

13
좀 더 명시적이고 로케일 문제가 없기 때문에 수락 된 답변보다 솔루션이 더 좋습니다. 마지막 부분을 놓치더라도 millis = millis % 1000은 형식이 지정된 문자열의 끝에 밀리 초를 올바르게 입력합니다.
Ondrej Burkert

7
@WesleyDeKeirsmaeker는 일반적으로 가독성이 간결함보다 중요합니다.
Alphaaa 2014

2
왜 몇 시간 동안 24 시간이 남았습니까?
baboo 2014 년

2
나눗셈이 연관되지 않음 : 50000 / (1000 * 60) = 0.8333333333 동안 50000 / 1000 * 60 = 3000.
farnett

3
'millis = millis % 1000'이 누락되었습니다. : D \ n 일이 필요하면 여기로 이동하십시오. 'long days = (millis / (1000 * 60 * 60 * 24));'
Adreamus 2015 년

38

(a) long 값에서 분 필드를 가져오고 (b) 원하는 날짜 형식을 사용하여 인쇄하는 세 가지 방법을 보여 드리겠습니다. 하나는 java.util.Calendar를 사용 하고 다른 하나는 Joda-Time을 사용하며 마지막은 Java 8 이상에 내장 된 java.time 프레임 워크를 사용합니다.

java.time 프레임 워크는 이전 번들 날짜-시간 클래스를 대체하며 JSR 310에 의해 정의되고 ThreeTen-Extra 프로젝트에 의해 확장 된 Joda-Time에서 영감을 받았습니다.

java.time 프레임 워크는 Java 8 이상을 사용할 때 사용하는 방법입니다. 그렇지 않으면 Android와 같이 Joda-Time을 사용하십시오. java.util.Date/.Calendar 클래스는 매우 문제가 많으므로 피해야합니다.

java.util.Date 및 .Calendar

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-Time

// 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.time

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 );

millisecondsSinceEpoch : 1289375173771 인스턴트 : 2010-11-10T07 : 46 : 13.771Z 출력 : 07 : 46 : 13 : 771


1
성능상의 이유나 다른 이유가 있습니까? 캘린더보다 Joda를 선호해야합니까?
Cratylus

1
이와 같은 간단한 경우에는 아닙니다. 일반적으로 Joda의 API가 더 잘 설계되었습니다. 예를 들어 자바 날짜는 변경 가능합니다. Joda DateTimes는 그렇지 않습니다. Joda는 날짜 및 달력 사이에서 앞뒤로 전환 할 필요없이 날짜 시간 클래스에서 거의 모든 기능에 액세스 할 수 있습니다, 또한 많은 프로그래머 친절
숀 패트릭 플로이드

내가 알아야 할 종속성이 있습니까?
Cratylus

2
좋은 대답이지만 JVM의 현재 기본 시간대에 암시 적으로 의존하는 대신 시간대를 지정하는 것이 좋습니다. 따라서 DateTime의 생성자에 대한 호출에는 두 번째 인수 인 DateTimeZone객체가 있습니다. 다음과 같이 :new DateTime( timestamp, DateTimeZone.forID( "America/Montreal" ) )
Basil Bourque

2
@Cratylus java.time 클래스 Joda-Time 및 Java와 함께 번들로 제공되는 이전 레거시 날짜-시간 클래스를 모두 대체 합니다 . Joda-Time은 동일한 사람인 Stephen Colbourne이 이끄는 두 프로젝트 인 java.time 클래스에 영감을주었습니다.
바질 우르 큐

22

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"

도움이 되길 바랍니다 ...


8
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);

2
이것은 정확하지 않은 것 같습니다. 합니까 TimeUnit.MILLISECONDS.toSeconds(), 예를 들어, 초 남은 초 같은 시간에 변환 밀리 초 시간과 분을 뺀? 솔루션에는 후자가 필요합니다.
Derek Mahar

이 메서드는 올바르지 않습니다 . 2019 년
0ddlyoko

6
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);

4

하기

logEvent.timeStamp / (1000*60*60)

몇 분이 아닌 몇 시간을 줄 것입니다. 시험:

logEvent.timeStamp / (1000*60)

그리고 당신은 다음과 같은 답을 얻게 될 것입니다.

TimeUnit.MILLISECONDS.toMinutes(logEvent.timeStamp)

그러나 TimeUnit.MILLISECONDS.toMinutes (logEvent.timeStamp)도 내 쓰레기를 제공합니다. 21489586은 분이 아닙니다!
Cratylus

1
1970 년 1 월 1 일 이후 경과 된 시간 (분)입니다.
Nico Huysamen 2010

좋아, 원하는 형식을 어떻게 얻습니까? Ie 10 : 50 : 40 : 450? 1970 년 이후 분 수를 사용하는 방법을 모르겠습니다.
Cratylus

죄송합니다. 이해하는 방법을 알고 싶다고 생각했습니다. seanizer의 게시물을 참조하십시오.
Nico Huysamen 2010

3

이 시도:

    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);

0
    long hours = TimeUnit.MILLISECONDS.toHours(timeInMilliseconds);
    long minutes = TimeUnit.MILLISECONDS.toMinutes(timeInMilliseconds - TimeUnit.HOURS.toMillis(hours));
    long seconds = TimeUnit.MILLISECONDS
            .toSeconds(timeInMilliseconds - TimeUnit.HOURS.toMillis(hours) - TimeUnit.MINUTES.toMillis(minutes));
    long milliseconds = timeInMilliseconds - TimeUnit.HOURS.toMillis(hours)
            - TimeUnit.MINUTES.toMillis(minutes) - TimeUnit.SECONDS.toMillis(seconds);
    return String.format("%02d:%02d:%02d:%d", hours, minutes, seconds, milliseconds);
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.