获取两个时间查得出年月

import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.List;



public class Date3 {
	//获取两个时间之间的  年月字符串   如 :2016-01  2016-02
	private static List<String> getMonthBetween(String minDate, String maxDate) throws ParseException {
		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;
	}

	public static void main(String[] args) throws ParseException {
		String startDate = "2016-02-01";
		String endDate = "2016-03-31";
		SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM");

		Calendar min = Calendar.getInstance();
		Calendar max = Calendar.getInstance();

		min.setTime(sdf.parse(startDate));
		min.set(min.get(Calendar.YEAR), min.get(Calendar.MONTH), 1);

		max.setTime(sdf.parse(endDate));
		max.set(max.get(Calendar.YEAR), max.get(Calendar.MONTH), 2);

		int months = (max.get(Calendar.YEAR) - min.get(Calendar.YEAR)) * 12 + max.get(Calendar.MONTH) - min.get(Calendar.MONTH) + 1;
		/**************************************************************/
 
		System.out.println("----------------开始时间---------------");
		System.out.println("开始年份:" + min.get(Calendar.YEAR));
		System.out.println("开始月份:" + (min.get(Calendar.MONTH)+1));
		System.out.println("开始年月:" + "" + min.get(Calendar.YEAR) + (min.get(Calendar.MONTH)+1));
		System.out.println("----------------结束时间---------------");
		System.out.println("结束年份:" + max.get(Calendar.YEAR));
		System.out.println("结束月份:" + (max.get(Calendar.MONTH)+1));
		System.out.println("结束年月:" + "" + max.get(Calendar.YEAR) + (max.get(Calendar.MONTH)+1));
		System.out.println("----------------相差月数---------------");
		System.out.println("相差月数:" + months);
		String tableName = "t_21_001_00000_";
		
		
		System.out.println("------------------------------");
		List<String> monthList = getMonthBetween(startDate, endDate);
		for (String string : monthList) {
                    fullTableName=tableName+string.replace("-", "").substring(2);
                   System.out.println(fullTableName);
               }
            }
         } 

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值