时间工具类

1、根据日期获取当天是周几

    /**
     * 根据日期获取当天是周几
     * @param dateTime 日期
     * @return 周几
     * @author lu
     * @since  1.0, 2020年7月30日
     */
    public static String getWeekOfDate(Date dateTime) {
        String[] weekDays = {"7","1","2","3","4","5","6"};
        Calendar calendar = Calendar.getInstance();
        calendar.setTime(dateTime);
        int i = calendar.get(Calendar.DAY_OF_WEEK) - 1;
        if(i<0) {
            i=0;
        }
        return weekDays[i];
    }

2、获取某段时间内的周一(二等等)的日期

     /**
     * 获取某段时间内的周一(二等等)的日期
     * @param dataBegin 开始日期
     * @param dataEnd 结束日期
     * @param weekDays 获取周几,1-6代表周一到周六。0代表周日
     * @return 返回日期List
     * @author lu
     * @since  1.0, 2020年7月30日
     */
    public static List<String> getDayOfWeekWithinDateInterval(String dataBegin, String dataEnd, int weekDays) {
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
        List<String> dateResult = new ArrayList<String>();
        Calendar cal = Calendar.getInstance();
        String[] dateInterval = {dataBegin, dataEnd};
        Date[] dates = new Date[dateInterval.length];
        for (int i = 0; i < dateInterval.length; i++) {
            String[] ymd = dateInterval[i].split("[^\\d]+");
            cal.set(Integer.parseInt(ymd[0]), Integer.parseInt(ymd[1]) - 1, Integer.parseInt(ymd[2]));
            dates[i] = cal.getTime();
        }
        for (Date date = dates[0]; date.compareTo(dates[1]) <= 0; ) {
            cal.setTime(date);
            cal.add(Calendar.DATE, 1);
            date = cal.getTime();
            if (cal.get(Calendar.DAY_OF_WEEK) - 1 == weekDays) {
                String format = sdf.format(date);
                dateResult.add(format);
            }
        }
        return dateResult;
    }

3、获取时间段内多个星期几的日期

/**
     * 获取某段时间内的周一(二等等)的日期
     * @param dataBegin 开始日期 例:2020-07-01
     * @param dataEnd 结束日 例:2020-08-12
     * @param weekDays 获取周几,1-6代表周一到周六。0代表周日 例:"0,2,3"
     * @return 返回日期List
     * @author lu
     * @since  1.0, 2020年7月30日
     */
    public static List<String> getDayOfWeekWithinDateInterval(String dataBegin, String dataEnd, String weekDays) {
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
        List<String> dateResult = new ArrayList<String>();
        Calendar cal = Calendar.getInstance();
        String[] dateInterval = {dataBegin, dataEnd};
        Date[] dates = new Date[dateInterval.length];
        for (int i = 0; i < dateInterval.length; i++) {
            String[] ymd = dateInterval[i].split("[^\\d]+");
            cal.set(Integer.parseInt(ymd[0]), Integer.parseInt(ymd[1]) - 1, Integer.parseInt(ymd[2]));
            dates[i] = cal.getTime();
        }
        for (Date date = dates[0]; date.compareTo(dates[1]) <= 0; ) {
            cal.setTime(date);
            cal.add(Calendar.DATE, 1);
            date = cal.getTime();
            if(weekDays.contains(String.valueOf(cal.get(Calendar.DAY_OF_WEEK) - 1))) {
                String format = sdf.format(date);
                dateResult.add(format);
            }
        }
        return dateResult;
    }

4、获取指定日期所在月份开始的时间戳

     /**
     * 获取指定日期所在月份开始的时间戳
     * @param date 指定日期
     * @return 指定日期所在月份开始的时间戳
     */
    public static Long getMonthBegin(Date date) {
        Calendar c = Calendar.getInstance();
        c.setTime(date);
        
        // 设置为1号,当前日期既为本月第一天
        c.set(Calendar.DAY_OF_MONTH, 1);
        // 将小时至0
        c.set(Calendar.HOUR_OF_DAY, 0);
        // 将分钟至0
        c.set(Calendar.MINUTE, 0);
        // 将秒至0
        c.set(Calendar.SECOND, 0);
        // 将毫秒至0
        c.set(Calendar.MILLISECOND, 0);
        // 获取本月第一天的时间戳
        return c.getTimeInMillis();
    }

5、获取指定日期所在月份结束的时间戳

     /**
     * 获取指定日期所在月份结束的时间戳
     * @param date 指定日期
     * @return 指定日期所有月份结束时间戳
     */
    public static Long getMonthEnd(Date date) {
        Calendar c = Calendar.getInstance();
        c.setTime(date);
        
        // 设置为当月最后一天
        c.set(Calendar.DAY_OF_MONTH, c.getActualMaximum(Calendar.DAY_OF_MONTH));
        // 将小时至23
        c.set(Calendar.HOUR_OF_DAY, 23);
        // 将分钟至59
        c.set(Calendar.MINUTE, 59);
        // 将秒至59
        c.set(Calendar.SECOND, 59);
        // 将毫秒至999
        c.set(Calendar.MILLISECOND, 999);
        // 获取本月最后一天的时间戳
        return c.getTimeInMillis();
    }

6、针对时间戳返回问题,返回的带时区时间戳

    /**
     * 针对时间戳返回问题,返回的带时区时间戳
     */
    public final static long getTimeByZone(Date date) {
        java.util.Calendar cal = java.util.Calendar.getInstance();
        int zoneOffset = cal.get(java.util.Calendar.ZONE_OFFSET);
        return date.getTime()+zoneOffset;
    }

7、时间戳转换成字符串

      /**
      * 时间戳转换成字符串
      */
     public static String getDateToString(long time) {
         Date d = new Date(time);
       SimpleDateFormat  sf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
         return sf.format(d);
     }

8、将字符串转为时间戳

     /**
      * 将字符串转为时间戳
      */
     public static long getStringToDate(String time) {
        SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
         Date date = new Date();
         try{
             date = sf.parse(time);
         } catch(ParseException e) {
             e.printStackTrace();
         }
         return date.getTime();
     }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值