Java 根据年号和第几周得到开始时间和结束时间

通常在做与时间相关的查询时,一个通用的做法是放入两个日历控件,一个是开始时间,一个是结束时间,用户在选择时间之后,校验时间合法性之后,就可以查询了,但在做小日本项目时遇到一个很奇葩的查询,这些用户不用开始时间结束时间,而是用这一年的第几周来查询出报表,个人觉得很不习惯,但还得做。

后台保留的时间格式是datetime类型的,而前台给出的条件是 年号 和第几周,比如 2014 年 第 5 周. 这个时候,你需要在后台用 Java 将 它转换成具体的开始时间,结束时间,然后再去数据库查询。转换的具体方法,分享如下 :

package com.training.controller;import java.util.Calendar;publicclassConvertDateTest{
    
    publicstaticvoid main(String[] args){
        
        ConvertDateTest cd =newConvertDateTest();
        System.out.println("开始时间: "+ cd.getStartDayOfWeekNo(2014,5));
        System.out.println("结束时间:"+ cd.getEndDayOfWeekNo(2014,5));    
        
    }
    
    /**
     * get first date of given month and year
     * @param year
     * @param month
     * @return
     */
    publicString getFirstDayOfMonth(int year,int month){
        String monthStr = month <10?"0"+ month :String.valueOf(month);
        return year +"-"+monthStr+"-"+"01";
    }
    
    /**
     * get the last date of given month and year
     * @param year
     * @param month
     * @return
     */
    publicString getLastDayOfMonth(int year,int month){
        Calendar calendar =Calendar.getInstance();
        calendar.set(Calendar.YEAR , year);
        calendar.set(Calendar.MONTH , month -1);
        calendar.set(Calendar.DATE ,1);
        calendar.add(Calendar.MONTH,1);
        calendar.add(Calendar.DAY_OF_YEAR ,-1);
        return calendar.get(Calendar.YEAR)+"-"+(calendar.get(Calendar.MONTH)+1)+"-"+
               calendar.get(Calendar.DAY_OF_MONTH);
    }
    
    /**
     * get Calendar of given year
     * @param year
     * @return
     */
    privateCalendar getCalendarFormYear(int year){
        Calendar cal =Calendar.getInstance();
        cal.set(Calendar.DAY_OF_WEEK,Calendar.MONDAY);      
        cal.set(Calendar.YEAR, year);return cal;
    }
    
    /**
     * get start date of given week no of a year
     * @param year
     * @param weekNo
     * @return
     */
    publicString getStartDayOfWeekNo(int year,int weekNo){
        Calendar cal = getCalendarFormYear(year);
        cal.set(Calendar.WEEK_OF_YEAR, weekNo);
        return cal.get(Calendar.YEAR)+"-"+(cal.get(Calendar.MONTH)+1)+"-"+
               cal.get(Calendar.DAY_OF_MONTH);    
        
    }
    
    /**
     * get the end day of given week no of a year.
     * @param year
     * @param weekNo
     * @return
     */
    publicString getEndDayOfWeekNo(int year,int weekNo){
        Calendar cal = getCalendarFormYear(year);
        cal.set(Calendar.WEEK_OF_YEAR, weekNo);
        cal.add(Calendar.DAY_OF_WEEK,6);return cal.get(Calendar.YEAR)+"-"+(cal.get(Calendar.MONTH)+1)+"-"+
               cal.get(Calendar.DAY_OF_MONTH);    
    }}



运行得到 2014 年第 5 周的开始时间和结束时间:

开始时间:2014-1-27结束时间:2014-2-2
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值