Как сравнить даты в Java? [дубликат]
этот вопрос уже есть ответ здесь:
- Java: как проверить, находится ли дата в определенном диапазоне? 11 ответов
как сравнить даты между ними в Java?
пример:
date1 - это 22-02-2010
дата2 составляет
дата3 это 25-12-2010
date3
- это всегда больше, чем date1
и date2
всегда сегодня. Как проверить, находится ли сегодняшняя дата между date1 и date 3?
11 ответов
дата и до и после методы и может быть по сравнению друг с другом следующим образом:
if(todayDate.after(historyDate) && todayDate.before(futureDate)) {
// In between
}
для всестороннего сравнения:
if(!historyDate.after(todayDate) && !futureDate.before(todayDate)) {
/* historyDate <= todayDate <= futureDate */
}
вы также можете дать Joda Времени идти, но обратите внимание, что:
Joda-время-это де-факто стандартная библиотека даты и времени для Java до Java SE 8. Теперь пользователям предлагается перейти на java.время (JSR-310).
Back-порты доступны для Java 6 и 7, а также Android.
Ниже приведены наиболее распространенный способ сравнения дат. Но я предпочитаю первый
Подход-1: Использование Даты.перед (), дата.после() и дата.equals ()
if(date1.after(date2)){
System.out.println("Date1 is after Date2");
}
if(date1.before(date2)){
System.out.println("Date1 is before Date2");
}
if(date1.equals(date2)){
System.out.println("Date1 is equal Date2");
}
Подход-2 : Дата.метод compareto()
if(date1.compareTo(date2)>0){
System.out.println("Date1 is after Date2");
}else if(date1.compareTo(date2)<0){
System.out.println("Date1 is before Date2");
}else{
System.out.println("Date1 is equal to Date2");
}
Подход - 3: Календарь.перед (), календарь.после() и календарь.equals ()
Calendar cal1 = Calendar.getInstance();
Calendar cal2 = Calendar.getInstance();
cal1.setTime(date1);
cal2.setTime(date2);
if(cal1.after(cal2)){
System.out.println("Date1 is after Date2");
}
if(cal1.before(cal2)){
System.out.println("Date1 is before Date2");
}
if(cal1.equals(cal2)){
System.out.println("Date1 is equal Date2");
}
tl; dr
LocalDate today = LocalDate.now( ZoneId.of( "America/Montreal" ) ) ;
Boolean isBetween =
( ! today.isBefore( localDate1 ) ) // “not-before” is short for “is-equal-to or later-than”.
&&
today.isBefore( localDate3 ) ;
или, лучше, если вы добавите ThreeTen-Extra библиотека для вашего проекта.
LocalDateRange.of(
LocalDate.of( … ) ,
LocalDate.of( … )
).contains(
LocalDate.now()
)
полуоткрытый подход, где начало включительно а концовка эксклюзивные.
плохой выбор формата
кстати, это плохой выбор формат для текстового представления даты или даты-времени. По возможности придерживайтесь стандарта ISO 8601 форматы. Форматы ISO 8601 однозначны, понятны для всех человеческих культур и легко анализируются машиной.
для значения только для даты стандартный формат-гггг-ММ-ДД. Обратите внимание, что этот формат имеет преимущество быть хронологическим при сортировке в алфавитном порядке.
LocalDate
на LocalDate
класс представляет значение только даты без времени суток и без часового пояса.
часовой пояс имеет решающее значение в определение даты. Для любого данного момента дата варьируется по всему миру по зонам. Например, через несколько минут после полуночи в Париж, Франция новый день, в то время как еще "вчера" в Квебека Монреале.
ZoneId z = ZoneId.of( "America/Montreal" );
LocalDate today = LocalDate.now( z );
DateTimeFormatter
поскольку входные строки имеют нестандартный формат, мы должны определить соответствующий шаблон форматирования.
DateTimeFormatter f = DateTimeFormatter.ofPattern( "dd-MM-uuuu" );
используйте это для анализа входных строк.
LocalDate start = LocalDate.parse( "22-02-2010" , f );
LocalDate stop = LocalDate.parse( "25-12-2010" , f );
в дату-время работа, как правило, лучше всего определить промежуток времени по полуоткрытому подходу, где начало включительно хотя концовка эксклюзивные. Поэтому мы хотим знать, сегодня то же самое или позже, чем начало, а также до остановки. Более краткий способ сказать "то же самое или позже, чем начало" - это "не до начала".
Boolean intervalContainsToday = ( ! today.isBefore( start ) ) && today.isBefore( stop ) ;
посмотреть ответ от gstackoverflow отображение списка методов сравнения, которые вы можете вызов.
о java.время
на java.время framework встроен в Java 8 и более поздние версии. Эти классы вытесняют беспокойных старых наследие классы даты и времени, такие как java.util.Date
, Calendar
, & SimpleDateFormat
.
на Joda Времени, теперь режим обслуживания, советует миграцию в java.время занятия.
чтобы узнать больше, см. Oracle Tutorial. И search Stack Overflow для многих примеров и объяснений. Спецификация JSR 310.
где получить java.время занятий?
-
Java SE 8 и SE 9 и позже
- встроенный.
- часть стандартного API Java в комплекте реализация.
- Java 9 добавляет некоторые незначительные функции и исправления.
-
Java SE 6 и SE 7
- большая часть java.функциональность времени обратно портирована на Java 6 & 7 в ThreeTen-Backport.
-
Android
- на ThreeTenABP проект приспосабливается ThreeTen-Backport (упомянуто выше) для Android конкретно.
- посмотреть как использовать ThreeTenABP....
в ThreeTen-Extra проект расширяет java.время с дополнительными занятиями. Этот проект является испытательной площадкой для возможных будущих дополнений к java.время. Здесь вы можете найти полезные классы, такие как Interval
, YearWeek
, YearQuarter
и больше.
UPDATE: этот раздел" Joda-Time " ниже оставлен нетронутым как история. The Joda Времени, теперь ремонт режим, советует миграцию в java.время классы.
Joda Времени
другие ответы верны в отношении связанного java.утиль.Дата и java.утиль.Календарные занятия. Но эти классы, как известно, хлопотное. Итак, вот пример кода, использующего Joda Времени 2.3 библиотека.
если вы действительно хотите дату без какой-либо части времени и без часового пояса, то используйте LocalDate
класса в Joda Времени. Этот класс предоставляет методы сравнения, включая compareTo
(используется с Java Comparators), isBefore
, isAfter
и isEqual
.
входы...
String string1 = "22-02-2010";
String string2 = "07-04-2010";
String string3 = "25-12-2010";
определите форматер, описывающий входные строки...
DateTimeFormatter formatter = DateTimeFormat.forPattern( "dd-MM-yyyy" );
используйте formatter для разбора строк на объекты LocalDate...
LocalDate localDate1 = formatter.parseLocalDate( string1 );
LocalDate localDate2 = formatter.parseLocalDate( string2 );
LocalDate localDate3 = formatter.parseLocalDate( string3 );
boolean is1After2 = localDate1.isAfter( localDate2 );
boolean is2Before3 = localDate2.isBefore( localDate3 );
дамп в консоли...
System.out.println( "Dates: " + localDate1 + " " + localDate2 + " " + localDate3 );
System.out.println( "is1After2 " + is1After2 );
System.out.println( "is2Before3 " + is2Before3 );
при запуске...
Dates: 2010-02-22 2010-04-07 2010-12-25
is1After2 false
is2Before3 true
чтобы увидеть, если второе-между два других (исключительно, что означает не равно ни одной конечной точке)...
boolean is2Between1And3 = ( ( localDate2.isAfter( localDate1 ) ) && ( localDate2.isBefore( localDate3 ) ) );
Работа С Промежутками Времени
если вы работаете с промежутками времени, я предлагаю изучить в Joda-Time классы:продолжительность, интервал и период. Такие методы, как overlap
и contains
сделать сравнение легко.
для текстовых представлений посмотрите ISO 8601 стандартные:
-
продолжительность
Формат: PnYnMnDTnHnMnS
пример: P3Y6M4DT12H30M5S
(означает "три года, шесть месяцев, четыре дня, двенадцать часов, тридцать минут и пять секунд") -
интервал
формат: начало/конец
пример: 2007-03-01T13:00:00Z/2008-05-11T15:30:00Z
классы Joda-Time могут работать со строками в обоих этих форматах как в качестве входных данных (синтаксический анализ), так и вывод (генерация строк).
Joda-Time выполняет сравнения с помощью Полуоткрытых подход, где начало диапазона включительно хотя концовка эксклюзивные. Этот подход является мудрым для обработки промежутков времени. Поиск StackOverflow для получения дополнительной информации.
сравните две даты:
Date today = new Date();
Date myDate = new Date(today.getYear(),today.getMonth()-1,today.getDay());
System.out.println("My Date is"+myDate);
System.out.println("Today Date is"+today);
if (today.compareTo(myDate)<0)
System.out.println("Today Date is Lesser than my Date");
else if (today.compareTo(myDate)>0)
System.out.println("Today Date is Greater than my date");
else
System.out.println("Both Dates are equal");
обновление для Java 8 и выше
эти методы существуют в LocalDate
, LocalTime
и LocalDateTime
классы.
эти классы встроены в Java 8 и более поздние версии. Большая часть java.функциональность времени обратно портирована на Java 6 & 7 в ThreeTen-Backport и далее адаптированы к Android на ThreeTenABP (см. как использовать...).
можно использовать Date.getTime()
которых:
возвращает количество миллисекунд с 1 января 1970 года, 00:00: 00 GMT представлен этим объектом Date.
это означает, что вы можете сравнить их так же, как цифры:
if (date1.getTime() <= date.getTime() && date.getTime() <= date2.getTime()) {
/*
* date is between date1 and date2 (both inclusive)
*/
}
/*
* when date1 = 2015-01-01 and date2 = 2015-01-10 then
* returns true for:
* 2015-01-01
* 2015-01-01 00:00:01
* 2015-01-02
* 2015-01-10
* returns false for:
* 2014-12-31 23:59:59
* 2015-01-10 00:00:01
*
* if one or both dates are exclusive then change <= to <
*/
используйте getTime (), чтобы получить числовое значение даты, а затем сравнить, используя возвращенные значения.
попробуй такое
public static boolean compareDates(String psDate1, String psDate2) throws ParseException{
SimpleDateFormat dateFormat = new SimpleDateFormat ("dd/MM/yyyy");
Date date1 = dateFormat.parse(psDate1);
Date date2 = dateFormat.parse(psDate2);
if(date2.after(date1)) {
return true;
} else {
return false;
}
}
этот код определяет сегодня в некоторой продолжительности.. на основе Кореи locale
Calendar cstart = Calendar.getInstance(Locale.KOREA);
cstart.clear();
cstart.set(startyear, startmonth, startday);
Calendar cend = Calendar.getInstance(Locale.KOREA);
cend.clear();
cend.set(endyear, endmonth, endday);
Calendar c = Calendar.getInstance(Locale.KOREA);
if(c.after(cstart) && c.before(cend)) {
// today is in startyear/startmonth/startday ~ endyear/endmonth/endday
}
этот метод работал для меня:
public static String daysBetween(String day1, String day2) {
String daysBetween = "";
SimpleDateFormat myFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
try {
Date date1 = myFormat.parse(day1);
Date date2 = myFormat.parse(day2);
long diff = date2.getTime() - date1.getTime();
daysBetween = ""+(TimeUnit.DAYS.convert(diff, TimeUnit.MILLISECONDS));
} catch (ParseException e) {
e.printStackTrace();
}
return daysBetween;
}