1

形式で 2 つの文字列の期間を取得するにはどうすればよいですYYYYMMDDTHHMMSSか?

Calendar クラスを使用してgetTimeInMillis(). これに関して私が抱えている問題は、一貫性がないことです。私が間違っていることは何ですか?このプログラムを実行するたびに、コンソールに 40 ~ 70 行の出力が表示されます。

public class DurationTester {

    /**
     * Get the duration between two given times
     * @param time1 yyyymmddThhmmss
     * @param time2 yyyymmddThhmmss
     * @return minutes between time1 and time2
     */
    public static int getDuration(String time1, String time2){
        int yyyy1 = Integer.parseInt(time1.substring(0,4));
        int mm1 = Integer.parseInt(time1.substring(4,6));
        int dd1 = Integer.parseInt(time1.substring(6,8));
        int hh1 = Integer.parseInt(time1.substring(9,11));
        int min1 = Integer.parseInt(time1.substring(11,13));

        int yyyy2 = Integer.parseInt(time2.substring(0,4));
        int mm2 = Integer.parseInt(time2.substring(4,6));
        int dd2 = Integer.parseInt(time2.substring(6,8));
        int hh2 = Integer.parseInt(time2.substring(9,11));
        int min2 = Integer.parseInt(time2.substring(11,13));

        Calendar cal1 = Calendar.getInstance();
        cal1.set(yyyy1, mm1, dd1, hh1, min1, 0);
        Calendar cal2 = Calendar.getInstance();
        cal2.set(yyyy2, mm2, dd2, hh2, min2, 0);
        long milliSec = cal1.getTimeInMillis()-cal2.getTimeInMillis();
        long nonNegativeMS = Math.abs(milliSec);
        long seconds = nonNegativeMS / 1000;
        long minutes = seconds / 60;        
        return (int)minutes;
    }

    public static void main(String[] args){
        String t1 = "20130108T150000";
        String t2 = "20130108T131500";

        int errors = 0;
        for(int i=0; i<5000; i++){
            int duration = getDuration(t1,t2);
            if(duration == 104){
                System.out.println("ERROR: Should only be 105 ("+errors++ +")");
            }
        }
    }
}
4

5 に答える 5

2

String を解析するために SimpleDateFormat API を使用できます。

public static void main(String[] args) {
    SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMdd'T'HHmmss");
    try {
        Date date1 = sdf.parse("20130108T150000");
        Date date2 = sdf.parse("20130108T131500");
        System.out.println((date1.getTime() - date2.getTime())/1000/60);
    } catch (ParseException e) {
       e.printStackTrace();
    }
}
于 2013-08-08T07:12:48.767 に答える
1

まず、あなたの日付変換はオフですCalendar月はインデックスがゼロです (つまり、Janurary実際には month です0)。そのため、 begin の代わりにTue Jan 08 15:00:00 EST 2013、日付が実際に に変換されていますFri Feb 08 15:00:00 EST 2013。これ自体は問題の原因ではありませんが、気がかりな。

代わりに、使用する必要があります...

public static final SimpleDateFormat SDF = new SimpleDateFormat("yyyyMMdd'T'HHmmss");

public static int getDuration(String time1, String time2){
    Date date1 = SDF.parse(time1);
    Date date2 = SDF.parse(time2);

    Calendar cal1 = Calendar.getInstance();
    cal1.setTime(date1);
    Calendar cal2 = Calendar.getInstance();
    cal2.setTime(date2);

String値を元に変換するにはDate

さて、あなたの問題の原因に...

Calendarを使用して値を設定しているためset(int year, int month, int date, int hourOfDay, int minute, int second)、カレンダー インスタンスには作成時のミリ秒が含まれています (作成された日時Calendar.getInstance()のセットが返されます)。Calendar

これにより、計算でエラーが発生します

期間に依存しCalendarたりDate、期間を計算したりしないでください。長期間にわたって信頼性が低いため、代わりにJodaTimeを使用する必要があります

DateTime dt1 = new DateTime(date1);
DateTime dt2 = new DateTime(date2);

Duration duration = new Duration(dt2, dt1);
System.out.println(duration.getStandardDays());
System.out.println(duration.getStandardHours());
System.out.println(duration.getStandardMinutes());
于 2013-08-08T07:26:01.080 に答える
1

これを試して

    String t1 = "20130108T150000";
    String t2 = "20130108T131500";
    DateFormat df=new SimpleDateFormat("yyyyMMdd'T'HHmmss");
    Date date1=df.parse(t1);
    Date date2=df.parse(t2);

    System.out.println(date2.getTime()-date1.getTime());  // time difference in mil-seconds
于 2013-08-08T07:01:12.830 に答える
1

これまでのオブジェクトSimpleDateFormatを解析するために を使用することをお勧めしますString

SimpleDateFormat date_format = new SimpleDateFormat("yyyyMMdd'T'HHmmSS");
Date dateParsed = date_format.parse(yourStringDate)

関数を使用してDate.getTime()、ミリ秒単位で同等の日付オブジェクトを取得し、2 つの日付オブジェクトの違いを実行できます。

于 2013-08-08T07:02:44.357 に答える