public class DateUtils extends Object
A suite of utilities surrounding the use of the
 Calendar and Date object.
DateUtils contains a lot of common methods considering manipulations of Dates or Calendars. Some methods require some extra explanation. The truncate, ceiling and round methods could be considered the Math.floor(), Math.ceil() or Math.round versions for dates This way date-fields will be ignored in bottom-up order. As a complement to these methods we've introduced some fragment-methods. With these methods the Date-fields will be ignored in top-down order. Since a date without a year is not a valid date, you have to decide in what kind of date-field you want your result, for instance milliseconds or days.
 Several methods are provided for adding to Date objects, of the form 
 addXXX(Date date, int amount). It is important to note these methods 
 use a Calendar internally (with default timezone and locale) and may
 be affected by changes to daylight saving time (DST).
 
| Modifier and Type | Field and Description | 
|---|---|
| static long | MILLIS_PER_DAYNumber of milliseconds in a standard day. | 
| static long | MILLIS_PER_HOURNumber of milliseconds in a standard hour. | 
| static long | MILLIS_PER_MINUTENumber of milliseconds in a standard minute. | 
| static long | MILLIS_PER_SECONDNumber of milliseconds in a standard second. | 
| static int | RANGE_MONTH_MONDAYA month range, the week starting on Monday. | 
| static int | RANGE_MONTH_SUNDAYA month range, the week starting on Sunday. | 
| static int | RANGE_WEEK_CENTERA week range, centered around the day focused. | 
| static int | RANGE_WEEK_MONDAYA week range, starting on Monday. | 
| static int | RANGE_WEEK_RELATIVEA week range, starting on the day focused. | 
| static int | RANGE_WEEK_SUNDAYA week range, starting on Sunday. | 
| static int | SEMI_MONTHThis is half a month, so this represents whether a date is in the top
 or bottom half of the month. | 
| Constructor and Description | 
|---|
| DateUtils()DateUtilsinstances should NOT be constructed in
 standard programming. | 
| Modifier and Type | Method and Description | 
|---|---|
| static Date | addDays(Date date,
              int amount)Adds a number of days to a date returning a new object. | 
| static Date | addHours(Date date,
                int amount)Adds a number of hours to a date returning a new object. | 
| static Date | addMilliseconds(Date date,
                              int amount)Adds a number of milliseconds to a date returning a new object. | 
| static Date | addMinutes(Date date,
                    int amount)Adds a number of minutes to a date returning a new object. | 
| static Date | addMonths(Date date,
                  int amount)Adds a number of months to a date returning a new object. | 
| static Date | addSeconds(Date date,
                    int amount)Adds a number of seconds to a date returning a new object. | 
| static Date | addWeeks(Date date,
                int amount)Adds a number of weeks to a date returning a new object. | 
| static Date | addYears(Date date,
                int amount)Adds a number of years to a date returning a new object. | 
| static Calendar | ceiling(Calendar date,
              int field)Gets a date ceiling, leaving the field specified as the most
 significant field. | 
| static Date | ceiling(Date date,
              int field)Gets a date ceiling, leaving the field specified as the most
 significant field. | 
| static Date | ceiling(Object date,
              int field)Gets a date ceiling, leaving the field specified as the most
 significant field. | 
| static long | getFragmentInDays(Calendar calendar,
                                  int fragment)Returns the number of days within the 
 fragment. | 
| static long | getFragmentInDays(Date date,
                                  int fragment)Returns the number of days within the 
 fragment. | 
| static long | getFragmentInHours(Calendar calendar,
                                    int fragment)Returns the number of hours within the 
 fragment. | 
| static long | getFragmentInHours(Date date,
                                    int fragment)Returns the number of hours within the 
 fragment. | 
| static long | getFragmentInMilliseconds(Calendar calendar,
                                                  int fragment)Returns the number of milliseconds within the 
 fragment. | 
| static long | getFragmentInMilliseconds(Date date,
                                                  int fragment)Returns the number of milliseconds within the 
 fragment. | 
| static long | getFragmentInMinutes(Calendar calendar,
                                        int fragment)Returns the number of minutes within the 
 fragment. | 
| static long | getFragmentInMinutes(Date date,
                                        int fragment)Returns the number of minutes within the 
 fragment. | 
| static long | getFragmentInSeconds(Calendar calendar,
                                        int fragment)Returns the number of seconds within the 
 fragment. | 
| static long | getFragmentInSeconds(Date date,
                                        int fragment)Returns the number of seconds within the 
 fragment. | 
| static boolean | isSameDay(Calendar cal1,
                  Calendar cal2)Checks if two calendar objects are on the same day ignoring time. | 
| static boolean | isSameDay(Date date1,
                  Date date2)Checks if two date objects are on the same day ignoring time. | 
| static boolean | isSameInstant(Calendar cal1,
                          Calendar cal2)Checks if two calendar objects represent the same instant in time. | 
| static boolean | isSameInstant(Date date1,
                          Date date2)Checks if two date objects represent the same instant in time. | 
| static boolean | isSameLocalTime(Calendar cal1,
                              Calendar cal2)Checks if two calendar objects represent the same local time. | 
| static Iterator<Calendar> | iterator(Calendar focus,
                int rangeStyle)Constructs an  Iteratorover each day in a date
 range defined by a focus date and range style. | 
| static Iterator<Calendar> | iterator(Date focus,
                int rangeStyle)Constructs an  Iteratorover each day in a date
 range defined by a focus date and range style. | 
| static Iterator<?> | iterator(Object focus,
                int rangeStyle)Constructs an  Iteratorover each day in a date
 range defined by a focus date and range style. | 
| static Date | parseDate(String str,
                  Locale locale,
                  String... parsePatterns)Parses a string representing a date by trying a variety of different parsers,
 using the default date format symbols for the given locale. | 
| static Date | parseDate(String str,
                  String... parsePatterns)Parses a string representing a date by trying a variety of different parsers. | 
| static Date | parseDateStrictly(String str,
                                  Locale locale,
                                  String... parsePatterns)Parses a string representing a date by trying a variety of different parsers,
 using the default date format symbols for the given locale.. | 
| static Date | parseDateStrictly(String str,
                                  String... parsePatterns)Parses a string representing a date by trying a variety of different parsers. | 
| static Calendar | round(Calendar date,
          int field)Rounds a date, leaving the field specified as the most
 significant field. | 
| static Date | round(Date date,
          int field)Rounds a date, leaving the field specified as the most
 significant field. | 
| static Date | round(Object date,
          int field)Rounds a date, leaving the field specified as the most
 significant field. | 
| static Date | setDays(Date date,
              int amount)Sets the day of month field to a date returning a new object. | 
| static Date | setHours(Date date,
                int amount)Sets the hours field to a date returning a new object. | 
| static Date | setMilliseconds(Date date,
                              int amount)Sets the miliseconds field to a date returning a new object. | 
| static Date | setMinutes(Date date,
                    int amount)Sets the minute field to a date returning a new object. | 
| static Date | setMonths(Date date,
                  int amount)Sets the months field to a date returning a new object. | 
| static Date | setSeconds(Date date,
                    int amount)Sets the seconds field to a date returning a new object. | 
| static Date | setYears(Date date,
                int amount)Sets the years field to a date returning a new object. | 
| static Calendar | toCalendar(Date date)Converts a  Dateinto aCalendar. | 
| static Calendar | truncate(Calendar date,
                int field)Truncates a date, leaving the field specified as the most
 significant field. | 
| static Date | truncate(Date date,
                int field)Truncates a date, leaving the field specified as the most
 significant field. | 
| static Date | truncate(Object date,
                int field)Truncates a date, leaving the field specified as the most
 significant field. | 
| static int | truncatedCompareTo(Calendar cal1,
                                    Calendar cal2,
                                    int field)Determines how two calendars compare up to no more than the specified 
 most significant field. | 
| static int | truncatedCompareTo(Date date1,
                                    Date date2,
                                    int field)Determines how two dates compare up to no more than the specified 
 most significant field. | 
| static boolean | truncatedEquals(Calendar cal1,
                              Calendar cal2,
                              int field)Determines if two calendars are equal up to no more than the specified 
 most significant field. | 
| static boolean | truncatedEquals(Date date1,
                              Date date2,
                              int field)Determines if two dates are equal up to no more than the specified 
 most significant field. | 
public static final long MILLIS_PER_SECOND
public static final long MILLIS_PER_MINUTE
public static final long MILLIS_PER_HOUR
public static final long MILLIS_PER_DAY
public static final int SEMI_MONTH
public static final int RANGE_WEEK_SUNDAY
public static final int RANGE_WEEK_MONDAY
public static final int RANGE_WEEK_RELATIVE
public static final int RANGE_WEEK_CENTER
public static final int RANGE_MONTH_SUNDAY
public static final int RANGE_MONTH_MONDAY
public DateUtils()
DateUtils instances should NOT be constructed in
 standard programming. Instead, the static methods on the class should
 be used, such as DateUtils.parseDate(str);.
This constructor is public to permit tools that require a JavaBean instance to operate.
public static boolean isSameDay(Date date1, Date date2)
Checks if two date objects are on the same day ignoring time.
28 Mar 2002 13:45 and 28 Mar 2002 06:01 would return true. 28 Mar 2002 13:45 and 12 Mar 2002 13:45 would return false.
date1 - the first date, not altered, not nulldate2 - the second date, not altered, not nullIllegalArgumentException - if either date is nullpublic static boolean isSameDay(Calendar cal1, Calendar cal2)
Checks if two calendar objects are on the same day ignoring time.
28 Mar 2002 13:45 and 28 Mar 2002 06:01 would return true. 28 Mar 2002 13:45 and 12 Mar 2002 13:45 would return false.
cal1 - the first calendar, not altered, not nullcal2 - the second calendar, not altered, not nullIllegalArgumentException - if either calendar is nullpublic static boolean isSameInstant(Date date1, Date date2)
Checks if two date objects represent the same instant in time.
This method compares the long millisecond time of the two objects.
date1 - the first date, not altered, not nulldate2 - the second date, not altered, not nullIllegalArgumentException - if either date is nullpublic static boolean isSameInstant(Calendar cal1, Calendar cal2)
Checks if two calendar objects represent the same instant in time.
This method compares the long millisecond time of the two objects.
cal1 - the first calendar, not altered, not nullcal2 - the second calendar, not altered, not nullIllegalArgumentException - if either date is nullpublic static boolean isSameLocalTime(Calendar cal1, Calendar cal2)
Checks if two calendar objects represent the same local time.
This method compares the values of the fields of the two objects. In addition, both calendars must be the same of the same type.
cal1 - the first calendar, not altered, not nullcal2 - the second calendar, not altered, not nullIllegalArgumentException - if either date is nullpublic static Date parseDate(String str, String... parsePatterns) throws ParseException
Parses a string representing a date by trying a variety of different parsers.
The parse will try each parse pattern in turn. A parse is only deemed successful if it parses the whole of the input string. If no parse patterns match, a ParseException is thrown.
The parser will be lenient toward the parsed date.str - the date to parse, not nullparsePatterns - the date format patterns to use, see SimpleDateFormat, not nullIllegalArgumentException - if the date string or pattern array is nullParseException - if none of the date patterns were suitable (or there were none)public static Date parseDate(String str, Locale locale, String... parsePatterns) throws ParseException
Parses a string representing a date by trying a variety of different parsers, using the default date format symbols for the given locale.
The parse will try each parse pattern in turn. A parse is only deemed successful if it parses the whole of the input string. If no parse patterns match, a ParseException is thrown.
The parser will be lenient toward the parsed date.str - the date to parse, not nulllocale - the locale whose date format symbols should be used. If null,
 the system locale is used (as per parseDate(String, String...)).parsePatterns - the date format patterns to use, see SimpleDateFormat, not nullIllegalArgumentException - if the date string or pattern array is nullParseException - if none of the date patterns were suitable (or there were none)public static Date parseDateStrictly(String str, String... parsePatterns) throws ParseException
Parses a string representing a date by trying a variety of different parsers.
The parse will try each parse pattern in turn. A parse is only deemed successful if it parses the whole of the input string. If no parse patterns match, a ParseException is thrown.
The parser parses strictly - it does not allow for dates such as "February 942, 1996".str - the date to parse, not nullparsePatterns - the date format patterns to use, see SimpleDateFormat, not nullIllegalArgumentException - if the date string or pattern array is nullParseException - if none of the date patterns were suitablepublic static Date parseDateStrictly(String str, Locale locale, String... parsePatterns) throws ParseException
Parses a string representing a date by trying a variety of different parsers, using the default date format symbols for the given locale..
The parse will try each parse pattern in turn. A parse is only deemed successful if it parses the whole of the input string. If no parse patterns match, a ParseException is thrown.
The parser parses strictly - it does not allow for dates such as "February 942, 1996".str - the date to parse, not nulllocale - the locale whose date format symbols should be used. If null,
 the system locale is used (as per parseDateStrictly(String, String...)).parsePatterns - the date format patterns to use, see SimpleDateFormat, not nullIllegalArgumentException - if the date string or pattern array is nullParseException - if none of the date patterns were suitablepublic static Date addYears(Date date, int amount)
Date is unchanged.date - the date, not nullamount - the amount to add, may be negativeDate with the amount addedIllegalArgumentException - if the date is nullpublic static Date addMonths(Date date, int amount)
Date is unchanged.date - the date, not nullamount - the amount to add, may be negativeDate with the amount addedIllegalArgumentException - if the date is nullpublic static Date addWeeks(Date date, int amount)
Date is unchanged.date - the date, not nullamount - the amount to add, may be negativeDate with the amount addedIllegalArgumentException - if the date is nullpublic static Date addDays(Date date, int amount)
Date is unchanged.date - the date, not nullamount - the amount to add, may be negativeDate with the amount addedIllegalArgumentException - if the date is nullpublic static Date addHours(Date date, int amount)
Date is unchanged.date - the date, not nullamount - the amount to add, may be negativeDate with the amount addedIllegalArgumentException - if the date is nullpublic static Date addMinutes(Date date, int amount)
Date is unchanged.date - the date, not nullamount - the amount to add, may be negativeDate with the amount addedIllegalArgumentException - if the date is nullpublic static Date addSeconds(Date date, int amount)
Date is unchanged.date - the date, not nullamount - the amount to add, may be negativeDate with the amount addedIllegalArgumentException - if the date is nullpublic static Date addMilliseconds(Date date, int amount)
Date is unchanged.date - the date, not nullamount - the amount to add, may be negativeDate with the amount addedIllegalArgumentException - if the date is nullpublic static Date setYears(Date date, int amount)
Date is unchanged.date - the date, not nullamount - the amount to setDate set with the specified valueIllegalArgumentException - if the date is nullpublic static Date setMonths(Date date, int amount)
Date is unchanged.date - the date, not nullamount - the amount to setDate set with the specified valueIllegalArgumentException - if the date is nullpublic static Date setDays(Date date, int amount)
Date is unchanged.date - the date, not nullamount - the amount to setDate set with the specified valueIllegalArgumentException - if the date is nullpublic static Date setHours(Date date, int amount)
Date is unchanged.date - the date, not nullamount - the amount to setDate set with the specified valueIllegalArgumentException - if the date is nullpublic static Date setMinutes(Date date, int amount)
Date is unchanged.date - the date, not nullamount - the amount to setDate set with the specified valueIllegalArgumentException - if the date is nullpublic static Date setSeconds(Date date, int amount)
Date is unchanged.date - the date, not nullamount - the amount to setDate set with the specified valueIllegalArgumentException - if the date is nullpublic static Date setMilliseconds(Date date, int amount)
Date is unchanged.date - the date, not nullamount - the amount to setDate set with the specified valueIllegalArgumentException - if the date is nullpublic static Calendar toCalendar(Date date)
Date into a Calendar.date - the date to convert to a CalendarNullPointerException - if null is passed inpublic static Date round(Date date, int field)
Rounds a date, leaving the field specified as the most significant field.
For example, if you had the date-time of 28 Mar 2002 13:45:01.231, if this was passed with HOUR, it would return 28 Mar 2002 14:00:00.000. If this was passed with MONTH, it would return 1 April 2002 0:00:00.000.
For a date in a timezone that handles the change to daylight saving time, rounding to Calendar.HOUR_OF_DAY will behave as follows. Suppose daylight saving time begins at 02:00 on March 30. Rounding a date that crosses this time would produce the following values:
date - the date to work with, not nullfield - the field from Calendar or SEMI_MONTHArithmeticException - if the year is over 280 millionpublic static Calendar round(Calendar date, int field)
Rounds a date, leaving the field specified as the most significant field.
For example, if you had the date-time of 28 Mar 2002 13:45:01.231, if this was passed with HOUR, it would return 28 Mar 2002 14:00:00.000. If this was passed with MONTH, it would return 1 April 2002 0:00:00.000.
For a date in a timezone that handles the change to daylight saving time, rounding to Calendar.HOUR_OF_DAY will behave as follows. Suppose daylight saving time begins at 02:00 on March 30. Rounding a date that crosses this time would produce the following values:
date - the date to work with, not nullfield - the field from Calendar or SEMI_MONTHIllegalArgumentException - if the date is nullArithmeticException - if the year is over 280 millionpublic static Date round(Object date, int field)
Rounds a date, leaving the field specified as the most significant field.
For example, if you had the date-time of 28 Mar 2002 13:45:01.231, if this was passed with HOUR, it would return 28 Mar 2002 14:00:00.000. If this was passed with MONTH, it would return 1 April 2002 0:00:00.000.
For a date in a timezone that handles the change to daylight saving time, rounding to Calendar.HOUR_OF_DAY will behave as follows. Suppose daylight saving time begins at 02:00 on March 30. Rounding a date that crosses this time would produce the following values:
date - the date to work with, either Date or Calendar, not nullfield - the field from Calendar or SEMI_MONTHIllegalArgumentException - if the date is nullClassCastException - if the object type is not a Date or CalendarArithmeticException - if the year is over 280 millionpublic static Date truncate(Date date, int field)
Truncates a date, leaving the field specified as the most significant field.
For example, if you had the date-time of 28 Mar 2002 13:45:01.231, if you passed with HOUR, it would return 28 Mar 2002 13:00:00.000. If this was passed with MONTH, it would return 1 Mar 2002 0:00:00.000.
date - the date to work with, not nullfield - the field from Calendar or SEMI_MONTHIllegalArgumentException - if the date is nullArithmeticException - if the year is over 280 millionpublic static Calendar truncate(Calendar date, int field)
Truncates a date, leaving the field specified as the most significant field.
For example, if you had the date-time of 28 Mar 2002 13:45:01.231, if you passed with HOUR, it would return 28 Mar 2002 13:00:00.000. If this was passed with MONTH, it would return 1 Mar 2002 0:00:00.000.
date - the date to work with, not nullfield - the field from Calendar or SEMI_MONTHIllegalArgumentException - if the date is nullArithmeticException - if the year is over 280 millionpublic static Date truncate(Object date, int field)
Truncates a date, leaving the field specified as the most significant field.
For example, if you had the date-time of 28 Mar 2002 13:45:01.231, if you passed with HOUR, it would return 28 Mar 2002 13:00:00.000. If this was passed with MONTH, it would return 1 Mar 2002 0:00:00.000.
date - the date to work with, either Date or Calendar, not nullfield - the field from Calendar or SEMI_MONTHIllegalArgumentException - if the date is nullClassCastException - if the object type is not a Date or CalendarArithmeticException - if the year is over 280 millionpublic static Date ceiling(Date date, int field)
Gets a date ceiling, leaving the field specified as the most significant field.
For example, if you had the date-time of 28 Mar 2002 13:45:01.231, if you passed with HOUR, it would return 28 Mar 2002 14:00:00.000. If this was passed with MONTH, it would return 1 Apr 2002 0:00:00.000.
date - the date to work with, not nullfield - the field from Calendar or SEMI_MONTHIllegalArgumentException - if the date is nullArithmeticException - if the year is over 280 millionpublic static Calendar ceiling(Calendar date, int field)
Gets a date ceiling, leaving the field specified as the most significant field.
For example, if you had the date-time of 28 Mar 2002 13:45:01.231, if you passed with HOUR, it would return 28 Mar 2002 14:00:00.000. If this was passed with MONTH, it would return 1 Apr 2002 0:00:00.000.
date - the date to work with, not nullfield - the field from Calendar or SEMI_MONTHIllegalArgumentException - if the date is nullArithmeticException - if the year is over 280 millionpublic static Date ceiling(Object date, int field)
Gets a date ceiling, leaving the field specified as the most significant field.
For example, if you had the date-time of 28 Mar 2002 13:45:01.231, if you passed with HOUR, it would return 28 Mar 2002 14:00:00.000. If this was passed with MONTH, it would return 1 Apr 2002 0:00:00.000.
date - the date to work with, either Date or Calendar, not nullfield - the field from Calendar or SEMI_MONTHIllegalArgumentException - if the date is nullClassCastException - if the object type is not a Date or CalendarArithmeticException - if the year is over 280 millionpublic static Iterator<Calendar> iterator(Date focus, int rangeStyle)
Constructs an Iterator over each day in a date
 range defined by a focus date and range style.
For instance, passing Thursday, July 4, 2002 and a
 RANGE_MONTH_SUNDAY will return an Iterator
 that starts with Sunday, June 30, 2002 and ends with Saturday, August 3,
 2002, returning a Calendar instance for each intermediate day.
This method provides an iterator that returns Calendar objects.
 The days are progressed using Calendar.add(int, int).
focus - the date to work with, not nullrangeStyle - the style constant to use. Must be one of
 RANGE_MONTH_SUNDAY, 
 RANGE_MONTH_MONDAY,
 RANGE_WEEK_SUNDAY,
 RANGE_WEEK_MONDAY,
 RANGE_WEEK_RELATIVE,
 RANGE_WEEK_CENTERIllegalArgumentException - if the date is nullIllegalArgumentException - if the rangeStyle is invalidpublic static Iterator<Calendar> iterator(Calendar focus, int rangeStyle)
Constructs an Iterator over each day in a date
 range defined by a focus date and range style.
For instance, passing Thursday, July 4, 2002 and a
 RANGE_MONTH_SUNDAY will return an Iterator
 that starts with Sunday, June 30, 2002 and ends with Saturday, August 3,
 2002, returning a Calendar instance for each intermediate day.
This method provides an iterator that returns Calendar objects.
 The days are progressed using Calendar.add(int, int).
focus - the date to work with, not nullrangeStyle - the style constant to use. Must be one of
 RANGE_MONTH_SUNDAY, 
 RANGE_MONTH_MONDAY,
 RANGE_WEEK_SUNDAY,
 RANGE_WEEK_MONDAY,
 RANGE_WEEK_RELATIVE,
 RANGE_WEEK_CENTERIllegalArgumentException - if the date is nullIllegalArgumentException - if the rangeStyle is invalidpublic static Iterator<?> iterator(Object focus, int rangeStyle)
Constructs an Iterator over each day in a date
 range defined by a focus date and range style.
For instance, passing Thursday, July 4, 2002 and a
 RANGE_MONTH_SUNDAY will return an Iterator
 that starts with Sunday, June 30, 2002 and ends with Saturday, August 3,
 2002, returning a Calendar instance for each intermediate day.
focus - the date to work with, either Date or Calendar, not nullrangeStyle - the style constant to use. Must be one of the range
 styles listed for the iterator(Calendar, int) method.IllegalArgumentException - if the date is nullClassCastException - if the object type is not a Date or Calendarpublic static long getFragmentInMilliseconds(Date date, int fragment)
Returns the number of milliseconds within the fragment. All datefields greater than the fragment will be ignored.
Asking the milliseconds of any date will only return the number of milliseconds of the current second (resulting in a number between 0 and 999). This method will retrieve the number of milliseconds for any fragment. For example, if you want to calculate the number of milliseconds past today, your fragment is Calendar.DATE or Calendar.DAY_OF_YEAR. The result will be all milliseconds of the past hour(s), minutes(s) and second(s).
Valid fragments are: Calendar.YEAR, Calendar.MONTH, both Calendar.DAY_OF_YEAR and Calendar.DATE, Calendar.HOUR_OF_DAY, Calendar.MINUTE, Calendar.SECOND and Calendar.MILLISECOND A fragment less than or equal to a SECOND field will return 0.
date - the date to work with, not nullfragment - the Calendar field part of date to calculateIllegalArgumentException - if the date is null or
 fragment is not supportedpublic static long getFragmentInSeconds(Date date, int fragment)
Returns the number of seconds within the fragment. All datefields greater than the fragment will be ignored.
Asking the seconds of any date will only return the number of seconds of the current minute (resulting in a number between 0 and 59). This method will retrieve the number of seconds for any fragment. For example, if you want to calculate the number of seconds past today, your fragment is Calendar.DATE or Calendar.DAY_OF_YEAR. The result will be all seconds of the past hour(s) and minutes(s).
Valid fragments are: Calendar.YEAR, Calendar.MONTH, both Calendar.DAY_OF_YEAR and Calendar.DATE, Calendar.HOUR_OF_DAY, Calendar.MINUTE, Calendar.SECOND and Calendar.MILLISECOND A fragment less than or equal to a SECOND field will return 0.
date - the date to work with, not nullfragment - the Calendar field part of date to calculateIllegalArgumentException - if the date is null or
 fragment is not supportedpublic static long getFragmentInMinutes(Date date, int fragment)
Returns the number of minutes within the fragment. All datefields greater than the fragment will be ignored.
Asking the minutes of any date will only return the number of minutes of the current hour (resulting in a number between 0 and 59). This method will retrieve the number of minutes for any fragment. For example, if you want to calculate the number of minutes past this month, your fragment is Calendar.MONTH. The result will be all minutes of the past day(s) and hour(s).
Valid fragments are: Calendar.YEAR, Calendar.MONTH, both Calendar.DAY_OF_YEAR and Calendar.DATE, Calendar.HOUR_OF_DAY, Calendar.MINUTE, Calendar.SECOND and Calendar.MILLISECOND A fragment less than or equal to a MINUTE field will return 0.
date - the date to work with, not nullfragment - the Calendar field part of date to calculateIllegalArgumentException - if the date is null or 
 fragment is not supportedpublic static long getFragmentInHours(Date date, int fragment)
Returns the number of hours within the fragment. All datefields greater than the fragment will be ignored.
Asking the hours of any date will only return the number of hours of the current day (resulting in a number between 0 and 23). This method will retrieve the number of hours for any fragment. For example, if you want to calculate the number of hours past this month, your fragment is Calendar.MONTH. The result will be all hours of the past day(s).
Valid fragments are: Calendar.YEAR, Calendar.MONTH, both Calendar.DAY_OF_YEAR and Calendar.DATE, Calendar.HOUR_OF_DAY, Calendar.MINUTE, Calendar.SECOND and Calendar.MILLISECOND A fragment less than or equal to a HOUR field will return 0.
date - the date to work with, not nullfragment - the Calendar field part of date to calculateIllegalArgumentException - if the date is null or 
 fragment is not supportedpublic static long getFragmentInDays(Date date, int fragment)
Returns the number of days within the fragment. All datefields greater than the fragment will be ignored.
Asking the days of any date will only return the number of days of the current month (resulting in a number between 1 and 31). This method will retrieve the number of days for any fragment. For example, if you want to calculate the number of days past this year, your fragment is Calendar.YEAR. The result will be all days of the past month(s).
Valid fragments are: Calendar.YEAR, Calendar.MONTH, both Calendar.DAY_OF_YEAR and Calendar.DATE, Calendar.HOUR_OF_DAY, Calendar.MINUTE, Calendar.SECOND and Calendar.MILLISECOND A fragment less than or equal to a DAY field will return 0.
date - the date to work with, not nullfragment - the Calendar field part of date to calculateIllegalArgumentException - if the date is null or 
 fragment is not supportedpublic static long getFragmentInMilliseconds(Calendar calendar, int fragment)
Returns the number of milliseconds within the fragment. All datefields greater than the fragment will be ignored.
Asking the milliseconds of any date will only return the number of milliseconds of the current second (resulting in a number between 0 and 999). This method will retrieve the number of milliseconds for any fragment. For example, if you want to calculate the number of seconds past today, your fragment is Calendar.DATE or Calendar.DAY_OF_YEAR. The result will be all seconds of the past hour(s), minutes(s) and second(s).
Valid fragments are: Calendar.YEAR, Calendar.MONTH, both Calendar.DAY_OF_YEAR and Calendar.DATE, Calendar.HOUR_OF_DAY, Calendar.MINUTE, Calendar.SECOND and Calendar.MILLISECOND A fragment less than or equal to a MILLISECOND field will return 0.
calendar - the calendar to work with, not nullfragment - the Calendar field part of calendar to calculateIllegalArgumentException - if the date is null or 
 fragment is not supportedpublic static long getFragmentInSeconds(Calendar calendar, int fragment)
Returns the number of seconds within the fragment. All datefields greater than the fragment will be ignored.
Asking the seconds of any date will only return the number of seconds of the current minute (resulting in a number between 0 and 59). This method will retrieve the number of seconds for any fragment. For example, if you want to calculate the number of seconds past today, your fragment is Calendar.DATE or Calendar.DAY_OF_YEAR. The result will be all seconds of the past hour(s) and minutes(s).
Valid fragments are: Calendar.YEAR, Calendar.MONTH, both Calendar.DAY_OF_YEAR and Calendar.DATE, Calendar.HOUR_OF_DAY, Calendar.MINUTE, Calendar.SECOND and Calendar.MILLISECOND A fragment less than or equal to a SECOND field will return 0.
calendar - the calendar to work with, not nullfragment - the Calendar field part of calendar to calculateIllegalArgumentException - if the date is null or 
 fragment is not supportedpublic static long getFragmentInMinutes(Calendar calendar, int fragment)
Returns the number of minutes within the fragment. All datefields greater than the fragment will be ignored.
Asking the minutes of any date will only return the number of minutes of the current hour (resulting in a number between 0 and 59). This method will retrieve the number of minutes for any fragment. For example, if you want to calculate the number of minutes past this month, your fragment is Calendar.MONTH. The result will be all minutes of the past day(s) and hour(s).
Valid fragments are: Calendar.YEAR, Calendar.MONTH, both Calendar.DAY_OF_YEAR and Calendar.DATE, Calendar.HOUR_OF_DAY, Calendar.MINUTE, Calendar.SECOND and Calendar.MILLISECOND A fragment less than or equal to a MINUTE field will return 0.
calendar - the calendar to work with, not nullfragment - the Calendar field part of calendar to calculateIllegalArgumentException - if the date is null or 
 fragment is not supportedpublic static long getFragmentInHours(Calendar calendar, int fragment)
Returns the number of hours within the fragment. All datefields greater than the fragment will be ignored.
Asking the hours of any date will only return the number of hours of the current day (resulting in a number between 0 and 23). This method will retrieve the number of hours for any fragment. For example, if you want to calculate the number of hours past this month, your fragment is Calendar.MONTH. The result will be all hours of the past day(s).
Valid fragments are: Calendar.YEAR, Calendar.MONTH, both Calendar.DAY_OF_YEAR and Calendar.DATE, Calendar.HOUR_OF_DAY, Calendar.MINUTE, Calendar.SECOND and Calendar.MILLISECOND A fragment less than or equal to a HOUR field will return 0.
calendar - the calendar to work with, not nullfragment - the Calendar field part of calendar to calculateIllegalArgumentException - if the date is null or 
 fragment is not supportedpublic static long getFragmentInDays(Calendar calendar, int fragment)
Returns the number of days within the fragment. All datefields greater than the fragment will be ignored.
Asking the days of any date will only return the number of days of the current month (resulting in a number between 1 and 31). This method will retrieve the number of days for any fragment. For example, if you want to calculate the number of days past this year, your fragment is Calendar.YEAR. The result will be all days of the past month(s).
Valid fragments are: Calendar.YEAR, Calendar.MONTH, both Calendar.DAY_OF_YEAR and Calendar.DATE, Calendar.HOUR_OF_DAY, Calendar.MINUTE, Calendar.SECOND and Calendar.MILLISECOND A fragment less than or equal to a DAY field will return 0.
calendar - the calendar to work with, not nullfragment - the Calendar field part of calendar to calculateIllegalArgumentException - if the date is null or 
 fragment is not supportedpublic static boolean truncatedEquals(Calendar cal1, Calendar cal2, int field)
cal1 - the first calendar, not nullcal2 - the second calendar, not nullfield - the field from Calendartrue if equal; otherwise falseIllegalArgumentException - if any argument is nulltruncate(Calendar, int), 
truncatedEquals(Date, Date, int)public static boolean truncatedEquals(Date date1, Date date2, int field)
date1 - the first date, not nulldate2 - the second date, not nullfield - the field from Calendartrue if equal; otherwise falseIllegalArgumentException - if any argument is nulltruncate(Date, int), 
truncatedEquals(Calendar, Calendar, int)public static int truncatedCompareTo(Calendar cal1, Calendar cal2, int field)
cal1 - the first calendar, not nullcal2 - the second calendar, not nullfield - the field from CalendarIllegalArgumentException - if any argument is nulltruncate(Calendar, int), 
truncatedCompareTo(Date, Date, int)public static int truncatedCompareTo(Date date1, Date date2, int field)
date1 - the first date, not nulldate2 - the second date, not nullfield - the field from CalendarIllegalArgumentException - if any argument is nulltruncate(Calendar, int), 
truncatedCompareTo(Date, Date, int)Copyright © 2001–2015 The Apache Software Foundation. All rights reserved.