Board logo

标题: Calendar----获取上月的起始时间和上月结束时间 [打印本页]

作者: look_w    时间: 2019-5-13 10:52     标题: Calendar----获取上月的起始时间和上月结束时间

我们在进行数据统计的时候,一个常用的场景是需要统计上月的数据,上月的数据获取需要拿到上月的第一天和最后一天。


实现代码如下:


        public static void main(String[] args) {
            Calendar c=Calendar.getInstance();
            c.add(Calendar.MONTH, -1);
            SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd  HH:mm:ss");
            String gtimelast = sdf.format(c.getTime()); //上月
            System.out.println(gtimelast);
            int lastMonthMaxDay=c.getActualMaximum(Calendar.DAY_OF_MONTH);
            System.out.println(lastMonthMaxDay);
            c.set(c.get(Calendar.YEAR), c.get(Calendar.MONTH), lastMonthMaxDay, 23, 59, 59);
            
            //按格式输出
            String gtime = sdf.format(c.getTime()); //上月最后一天
            System.out.println(gtime);
            SimpleDateFormat sdf2 = new SimpleDateFormat("yyyy-MM-01  00:00:00");
            String gtime2 = sdf2.format(c.getTime()); //上月第一天
            System.out.println(gtime2);
        }



当前时间是 2017-07-31时,输出结果如下:






这里需要注意

① Calendar除了getActualMaximum方法之外,还有一个看起来类似的方法getMaximum,但是这两个方法是不同的:
getActualMaximum 返回实际的最大数值,getMaximum 返回的是可能的最大数值。


上面的代码如果改成getMaximum,那么一般情况都会恒定的返回31 (月份中可能的最大天数是31)


也就是说如果使用getMaximum,当前时间是2017-07-31时,推算出上个月的时间为2017-06-31,因为6月没有31号,所以会出错,导致上月最大时间变成2017-07-01。






② Calendar 的月份取值范围是 0 - 11 , 0代表1月 11代表12月份
(这是因为Java中的月份遵循了罗马历中的规则:当时一年中的月份数量是不固定的,第一个月是JANUARY。而Java中Calendar.MONTH返回的数值其实是当前月距离第一个月有多少个月份的数值,JANUARY在Java中返回“0”,所以我们操作月份的时候会根据需要做 +1 或 -1 的处理)




欢迎光临 电子技术论坛_中国专业的电子工程师学习交流社区-中电网技术论坛 (http://bbs.eccn.com/) Powered by Discuz! 7.0.0