дни между двумя датами сравнивать -> проще? - PullRequest
4 голосов
/ 27 апреля 2011

Привет, я спрашиваю себя, есть ли более простой способ узнать количество дней между двумя датами.

Я хочу только дни, не смотря на часы или минуты.

Поэтому, если сегодня понедельник, а дата, с которой я хочу сравнить, - среда, то дни между ними - 2 (время не имеет значения)

Поэтому я использую этот код:

        Calendar c = Calendar.getInstance();
        // Only the day:
        c.set(Calendar.HOUR, 0);
        c.set(Calendar.MINUTE, 0);
        c.set(Calendar.SECOND, 0);
        c.set(Calendar.MILLISECOND, 0);

        Calendar to = Calendar.getInstance();
        to.setTime(date);
        to.set(Calendar.HOUR, 0);
        to.set(Calendar.MINUTE, 0);
        to.set(Calendar.SECOND, 0);
        to.set(Calendar.MILLISECOND, 0);
        date = to.getTime();

        long millsPerDay = 1000 * 60 * 60 * 24;

        long dayDiff = ( date.getTime() - dateToday.getTime() ) / millsPerDay;

после этого кода у меня есть дни в длинном названном dayDiff. но действительно ли необходимо сделать календарь даты, установить время 00: 00: 00: 00 и сохранить to.getTime() в date?

Редактировать: После использования joda-time : Можно ли с помощью joda-time получать информацию о днях, например: разница == 1 ==> завтра или разница == -1 ==> вчера или я должен сделать это вручную?

Ответы [ 5 ]

7 голосов
/ 28 апреля 2011

Для указанной задачи я всегда использую этот удобный способ: (без lib, только API Java 5)

import java.util.concurrent.TimeUnit;

Date d1 = ...
Date d2 = ...

long daysBetween = TimeUnit.MILLISECONDS.toDays(d2.getTime() - d1.getTime());

Наслаждайтесь!

7 голосов
/ 27 апреля 2011

Вы можете использовать API JodaTime , как показано здесь .

3 голосов
/ 27 апреля 2011
public long dayDiff(Date d1, Date d2) {
    final long DAY_MILLIS = 1000 * 60 * 60 * 24;
    long day1 = d1.getTime() / DAY_MILLIS;
    long day2 = d2.getTime() / DAY_MILLIS;
    return (day1 - day2);
}

Извините за мою невнимательность

1 голос
/ 14 июня 2012

Вот аналитический метод дневной разницы, не основанный на опасных миллисекундных преобразованиях:

public static int dayDiff(Calendar to, Calendar from){
    int result = 0;
    int years;


    // global year difference from 1.jan to 1.jan
    years = to.get(Calendar.YEAR) - from.get(Calendar.YEAR);
    result = years * 365; 

    // adding days for simple leap years ( divisible by 4 ). This an approximation that will be corrected by the negative leap years formula.
    result += (to.get(Calendar.YEAR)-1)/4 - (from.get(Calendar.YEAR)-1)/4;

    // removing days for negative leap years ( divisible by 100 ). This is still an approximation that will be corrected by the big leap years formula.
    result -= (to.get(Calendar.YEAR)-1)/100 - (from.get(Calendar.YEAR)-1)/100;

    // adding days for big leap years ( divisible by 400 ). After this formula, the days count from 1.jan.<from> to 1.jan.<to> is correct.
    result += (to.get(Calendar.YEAR)-1)/400 - (from.get(Calendar.YEAR)-1)/400;

    // adding month of to-year
    for(int m=0; m<to.get(Calendar.MONTH ); m++){
        result += daysInMonth(m, to.get(Calendar.YEAR));
    }

    // substracting month of from-year
    for(int m=0; m<from.get(Calendar.MONTH ); m++){
        result -= daysInMonth(m, from.get(Calendar.YEAR));
    }

    // adding days of to-year
    result += to.get(Calendar.DAY_OF_MONTH ); 


    // substracting days of from-year
    result -= from.get(Calendar.DAY_OF_MONTH ); 

    return result;

}

private static int daysInMonth(int m, int y){
    if(m==3 || m==5 || m==8 || m==10) return 30;
    if(m==1)
        if(isLeapYear(y)) return 29;
        else return 28;
    return 31;
}


private static boolean isLeapYear(int y){
    return (isSimpleLeapYear(y) && !isNegativeLeapYear(y)) || isBigLeapYear(y);
}

private static boolean isSimpleLeapYear(int y){
    return y%4 == 0;
}

private static boolean isNegativeLeapYear(int y){
    return y%100 == 0;
}

private static boolean isBigLeapYear(int y){
    return y%400 == 0;
}

}

1 голос
/ 27 апреля 2011

Вместо того, чтобы устанавливать все нерелятивные значения в 0, вы можете использовать общие lang DateUtils.truncate

В любом случае, dayDiff (start-end) / milliesPerDay не будет работать корректно из-за изменений Daylight Save.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...