แปลงเวลาประทับเป็นมิลลิวินาทีเป็นเวลาที่จัดรูปแบบสตริงใน Java


126

ฉันพยายามที่จะแปลงค่ายาว ( จำนวนมิลลิวินาทีที่ผ่านไปจาก 1970/01/01 เช่น 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สำหรับคำอธิบายของสตริงรูปแบบอื่นที่คลาสยอมรับ

ดูตัวอย่างที่รันได้โดยใช้อินพุต 1200 ms


8
ความคิดเห็น: HH จะพิมพ์ชั่วโมงในวันนั้น (0-23) ไม่ใช่จำนวนชั่วโมงทั้งหมดที่ล่วงเลยไปตั้งแต่ปี 1970 เพียงแค่พูดว่า '
JohnyTex

4
และอย่าลืม. ไม่สามารถใช้ SimpleDateFormat แบบเก่าแบบมัลติเธรดได้
keiki

ในการนำเข้าSimpleDateFormatให้ใช้การนำเข้าดังนี้import java.text.*;
Naveen Kumar RB

1
FYI, ลำบากเก่าชั้นเรียนวันที่เวลาเช่นjava.util.Date, java.util.Calendarและjava.text.SimpleDateFormatตอนนี้มรดกแทนที่โดยjava.timeชั้นเรียนที่สร้างขึ้นใน Java 8 และต่อมา ดูการสอนโดยออราเคิล ดู: 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

2
ทำไมเหลือ 24 ชั่วโมง?
baboo

2
กองไม่สัมพันธ์: 50000 / (1000 * 60) = 0.8333333333 ในขณะที่ 50000/1000 * 60 = 3000
ฟาร์เน็ต

3
'millis = millis% 1000' หายไป: D \ n และถ้าคุณต้องการวันไปที่นี่: 'long days = (millis / (1000 * 60 * 60 * 24));'
Adreamus

38

ฉันจะแสดงสามวิธีในการ (a) รับฟิลด์นาทีจากค่า long และ (b) พิมพ์โดยใช้รูปแบบวันที่ที่คุณต้องการ หนึ่งใช้java.util.Calendarอีกอันใช้Joda-Timeและอันสุดท้ายใช้ java.time framework ที่สร้างใน Java 8 และใหม่กว่า

เฟรมเวิร์ก java.time แทนที่คลาสวันที่และเวลาเก่าที่รวมไว้และได้รับแรงบันดาลใจจาก Joda-Time ซึ่งกำหนดโดย JSR 310 และขยายโดยโครงการ ThreeTen-Extra

java.time framework เป็นวิธีที่จะใช้เมื่อใช้ 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 เวลา

// 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
ในกรณีง่ายๆเช่นนี้ไม่ โดยทั่วไป: API ของ Joda ได้รับการออกแบบให้ดีขึ้น เช่น java Dates ไม่สามารถเปลี่ยนแปลงได้ Joda DateTimes ไม่ได้ Joda เป็นโปรแกรมเมอร์ที่เป็นมิตรมากขึ้นคุณสามารถเข้าถึงฟังก์ชันเกือบทั้งหมดจากคลาส DateTime โดยไม่ต้องแปลงไปมาระหว่างวันที่และปฏิทิน
Sean Patrick Floyd

มีการอ้างอิงใด ๆ ที่ฉันควรทราบหรือไม่?
Cratylus

2
คำตอบที่ดี แต่ฉันขอแนะนำให้ระบุเขตเวลาแทนโดยปริยายในเขตเวลาเริ่มต้นปัจจุบันของ JVM ดังนั้นการเรียกตัวสร้าง DateTime จะมีอาร์กิวเมนต์ที่สองคือDateTimeZoneวัตถุ ดังนี้new DateTime( timestamp, DateTimeZone.forID( "America/Montreal" ) )
Basil Bourque

2
@Cratylus คลาส java.time แทนที่ทั้ง Joda-Time และคลาสวันที่เวลาเดิมที่มาพร้อมกับ Java Joda-Time เป็นแรงบันดาลใจให้กับคลาส java.time ทั้งสองโปรเจ็กต์ที่นำโดย Stephen Colbourne ชายคนเดียวกัน
Basil Bourque

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

วิธีนี้ไม่ถูกต้องจะส่งคืน431220: 25873204: 1552392282: 0ถ้าฉันต้องการแปลงวันที่12 มีนาคม 2019เวลา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

1
เป็นจำนวนนาทีที่ผ่านไปตั้งแต่ 01/01/1970
Nico Huysamen

ตกลงฉันจะได้รูปแบบที่ต้องการได้อย่างไร เช่น 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.