/**
* 获取date1相距date2多少天, date2>date1 * @param date1 * @param date2 * @return * @throws ParseException */ public static int getDaysSpace(String date1,String date2){ Calendar cal = Calendar.getInstance(); cal.setTime(getDate(date1, "yyyyMMdd")); long time1 = cal.getTimeInMillis(); cal.setTime(getDate(date2, "yyyyMMdd")); long time2 = cal.getTimeInMillis(); long between_days=(time2-time1)/(1000*3600*24); return Integer.parseInt(String.valueOf(between_days)); }
/**
* 获取date1相距date2几个月, date2>date1 * @param date1 * @param date2 * @return * @throws ParseException */ public static float getMonthSpace(String date1, String date2){ float result = 0; Calendar c1 = Calendar.getInstance(); Calendar c2 = Calendar.getInstance(); c1.setTime(getDate(date1, "yyyyMMdd")); c2.setTime(getDate(date2, "yyyyMMdd")); if(c2.get(Calendar.DATE) - c1.get(Calendar.DATE) >= 0){ result = (c2.get(Calendar.YEAR) - c1.get(Calendar.YEAR)) * 12.0f + (c2.get(Calendar.MONTH) - c1.get(Calendar.MONTH)) + (c2.get(Calendar.DATE) - c1.get(Calendar.DATE))/30.0f; }else{ result = (c2.get(Calendar.YEAR) - c1.get(Calendar.YEAR)) * 12.0f + (c2.get(Calendar.MONTH) - c1.get(Calendar.MONTH)) - 1.0f + (c2.get(Calendar.DATE) - c1.get(Calendar.DATE))/30.0f; } DecimalFormat df = new DecimalFormat("0.00"); return Float.parseFloat(df.format(result)); }
/**
* 获取date1相距date2几年, date2>date1 * @param date1 * @param date2 * @return * @throws ParseException */ public static float getYearSpace(String date1, String date2) { DecimalFormat df = new DecimalFormat("0.00"); return Float.parseFloat(df.format(getMonthSpace(date1, date2)/12.0f)); }