网站建设诚信服务网络推广外包公司排名
在一些需要统计类的需求中可能会计算同比/环比数据,往往我们拿到的并不是每个月的准确时间,需要自行计算,一点一点计算还是挺麻烦的,因此搞一个工具类出来
工具类
public static void main(String[] args) {//为了准确,这里使用的时间毫秒值long beginTime = 1577836800000L;long endTime = 1700994771650L;// 将毫秒值转换为Instant对象Instant startInstant = Instant.ofEpochMilli(beginTime);Instant endInstant = Instant.ofEpochMilli(endTime);// 转换为LocalDate对象LocalDate startDate = startInstant.atZone(ZoneId.systemDefault()).toLocalDate();LocalDate endDate = endInstant.atZone(ZoneId.systemDefault()).toLocalDate();// 计算每个月的时间区间LocalDate currentMonthStart = startDate.withDayOfMonth(1);while (!currentMonthStart.isAfter(endDate)) {LocalDate currentMonthEnd = currentMonthStart.plusMonths(1).minusDays(1);// 处理结束时间在下个月的情况if (currentMonthEnd.isAfter(endDate)) {currentMonthEnd = endDate;}DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd");System.out.println("开始时间:" + currentMonthStart.format(formatter) + " 结束时间:" + currentMonthEnd.format(formatter));// 移动到下个月的开始currentMonthStart = currentMonthStart.plusMonths(1);}}