今天出现一个很奇怪的问题,使用calendar 来处理日期时,获取指定月的日期时,出现了一个异常,当这个月有31天时就是正确的,但如果不是31天结果就不对。
/**
* 获取某月的最后一天 如201712结果为2017-12-30
* @param year
* @param month
* @return
*/
public static String getLastday(String year,String month){
Calendar cal= Calendar.getInstance();
cal.set(Calendar.YEAR ,Integer.parseInt(year));
cal.set(Calendar.MONTH ,Integer.parseInt(month)-1);
cal.set(Calendar.DAY_OF_MONTH ,cal.getActualMaximum(Calendar.DATE));
return new SimpleDateFormat("yyyy-MM-dd").format(cal.getTime());
}
测试:
public static void main(String[] args) throws SQLException {
String year = "2019";
for (int i = 1; i <= 12; i++) {
String lastday = getLastday(year, String.valueOf(i));
System.out.println("last day:" + lastday + "--> month: " + String.valueOf(i));
}
}
结果:
last day:2019-01-31--> month: 1
last day:2019-03-03--> month: 2
last day:2019-03-31--> month: 3
last day:2019-05-01--> month: 4
last day:2019-05-31--> month: 5
last day:2019-07-01--> month: 6
last day:2019-07-31--> month: 7
last day:2019-08-31--> month: 8
last day:2019-10-01--> month: 9
last day:2019-10-31--> month: 10
last day:2019-12-01--> month: 11
last day:2019-12-31--> month: 12
注意:calendar 处理日期时,把每个月都以31天处理,如果这个月没有31天就会出问题
解决方案:
/**
* 获取某月的最后一天 如201712结果为2017-12-30
* @param year
* @param month
* @return
*/
public static String getLastday(String year,String month){
LocalDate firstDayOfCurrentDate = LocalDate.of(Integer.parseInt(year), Integer.parseInt(month), 1);
LocalDate lastDayOfCurrentDate = firstDayOfCurrentDate.with(TemporalAdjusters.lastDayOfMonth());
return lastDayOfCurrentDate.toString();
}
测试:
public static void main(String[] args) throws SQLException {
String year = "2019";
for (int i = 1; i <= 12; i++) {
String lastday = getLastday(year, String.valueOf(i));
System.out.println("last day:" + lastday + "--> month: " + String.valueOf(i));
}
}
结果:
last day:2019-01-31--> month: 1
last day:2019-02-28--> month: 2
last day:2019-03-31--> month: 3
last day:2019-04-30--> month: 4
last day:2019-05-31--> month: 5
last day:2019-06-30--> month: 6
last day:2019-07-31--> month: 7
last day:2019-08-31--> month: 8
last day:2019-09-30--> month: 9
last day:2019-10-31--> month: 10
last day:2019-11-30--> month: 11
last day:2019-12-31--> month: 12
因篇幅问题不能全部显示,请点此查看更多更全内容