获取时间段内的所有月份yyyy-MM

    xiaoxiao2022-07-03  100

    1.util

    package com.etone.job.report.util; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Calendar; import java.util.List; public class GetMontnUtil { /** * * @param minDate 最小时间 2015-01 * @param maxDate 最大时间 2015-10 * @return 日期集合 格式为 年-月 * @throws Exception */ public static List<String> getMonthBetween(String minDate, String maxDate) throws Exception { ArrayList<String> result = new ArrayList<String>(); SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM");//格式化为年月 Calendar min = Calendar.getInstance(); Calendar max = Calendar.getInstance(); min.setTime(sdf.parse(minDate)); min.set(min.get(Calendar.YEAR), min.get(Calendar.MONTH), 1); max.setTime(sdf.parse(maxDate)); max.set(max.get(Calendar.YEAR), max.get(Calendar.MONTH), 2); Calendar curr = min; while (curr.before(max)) { result.add(sdf.format(curr.getTime())); curr.add(Calendar.MONTH, 1); } return result; } }

    1.demo

    public static void main(String[] args) { try { List<String> list = GetMontnUtil.getMonthBetween("2018-01", "2019-05"); for (String s : list) { System.out.println("s:"+ s); } } catch (Exception e) { e.printStackTrace(); } }

    结果

    s:2018-01 s:2018-02 s:2018-03 s:2018-04 s:2018-05 s:2018-06 s:2018-07 s:2018-08 s:2018-09 s:2018-10 s:2018-11 s:2018-12 s:2019-01 s:2019-02 s:2019-03 s:2019-04 s:2019-05

    适用于月报表统计数据

    最新回复(0)