ミリ秒単位のタイムスタンプをJavaの文字列形式の時間に変換する


126

長い値(1970年 1月1日から経過したミリ秒数、つまりエポック)をフォーマットの時間に変換しようとしています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を参照してください。

1200 msの入力を使用した実行可能な例を参照してください。


8
コメント:HHは1970年から経過した時間の合計ではなく、その日付の時間(0〜23)を出力します。
JohnyTex 2014

4
そして、忘れないでください。古いSimpleDateFormatはマルチスレッドでは使用できません。
keiki

インポートにSimpleDateFormat次のように、インポートを使用import java.text.*;
ナビーン・クマールRB

1
FYI、といった面倒な古い日付時刻クラスjava.util.Datejava.util.Calendarjava.text.SimpleDateFormat今のレガシーに取って代わられ、java.timeの後にJavaの8とに組み込まれたクラス。Oracleによるチュートリアル参照してください。参照:stackoverflow.com/a/4142428/642706
バジルブルク

1
ログイベントの種類は何ですか?質問に記入してください。
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
私はあなたの解決策を受け入れられた答えよりも好きです。それは、それがもう少し明示的で、ロケールの問題に悩まされないためです。最後の部分を見逃しますが、ミリ秒=ミリ秒%1000。これにより、フォーマットされた文字列の最後にミリ秒が正しく挿入されます。
Ondrej Burkert 2014年

7
@WesleyDeKeirsmaekerでは、一般に、簡潔さよりも読みやすさが重要です。
Alphaaa

2
なぜ24時間で何が残っているのですか?
baboo 2014

2
部門は連想ではありません:50000 /(* 60 1000)= 0.8333333333 / 1000 * 60 = 3000 50000中
farnett

3
'millis = millis%1000'がありません:D \ n日が必要な場合は、次のようにしてください: 'long days =(millis /(1000 * 60 * 60 * 24));'
Adreamus 2015

38

(a)長い値から分のフィールドを取得し、(b)希望する日付形式を使用して印刷する3つの方法を紹介します。1つはjava.util.Calendarを使用し、もう1つはJoda -Timeを使用し、最後はJava 8以降に組み込まれたjava.timeフレームワークを使用します。

java.timeフレームワークは、古いバンドルされた日時クラスに取って代わり、Joda 310によって定義されたJoda-Timeに触発され、ThreeTen-Extraプロジェクトによって拡張されました。

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

ジョーダタイム

// 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 instant:2010-11-10T07:46:13.771Z output:07:46:13:771


1
パフォーマンス上の理由やその他の理由はありますか、JodaをCalendarより優先する必要がありますか?
Cratylus、2010年

1
このような単純なケースでは、違います。一般的に、JodaのAPIはより良く設計されています。たとえば、Javaの日付は変更可能ですJodaの日付と時刻は変更できません。Jodaはよりプログラマーフレンドリーでもあり、DateとCalendarの間で相互に変換する必要なく、DateTimeクラスのほぼすべての機能にアクセスできます
Sean Patrick Floyd

注意すべき依存関係はありますか?
Cratylus、2010年

2
良い答えですが、JVMの現在のデフォルトのタイムゾーンに暗黙的に依存するのではなく、タイムゾーンも指定することをお勧めします。したがって、DateTimeのコンストラクターへの呼び出しには、2番目の引数であるDateTimeZoneオブジェクトがあります。このように:new DateTime( timestamp, DateTimeZone.forID( "America/Montreal" ) )
バジルブルク'09

2
@Cratylus java.timeクラスは、Joda -Timeと、Javaにバンドルされた古いレガシー日時クラスの両方に取って代わります。Joda-Timeはjava.timeクラスに影響を与えました。どちらのプロジェクトも同じ人物、Stephen Colbourneが率いています。
バジルブルク

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
これは正しくないようです。DOESはTimeUnit.MILLISECONDS.toSeconds()、例えば、時間と分を引いた後、数秒で同じ期間または残りの秒にミリ秒に変換しますか?ソリューションには後者が必要です。
Derek Mahar

この方法が間違っている、それが返されます431220:25873204:1552392282:0私は日付変換したい場合は2019年3月12日に13h04 42S
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 2010年

1
1970年1月1日から経過した分数です。
Nico Huysamen、2010年

わかりました、それで私はどのように私が望むフォーマットを得るのですか?つまり、10:50:40:450?1970
。– Cratylus

すみません、それを理解する方法を知りたいと思っただけです。それをカバーするはずのseanizerによる投稿を見てください。
Nico Huysamen

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.