jiangping
2025-06-09 5ecb8706b917aa86f43e44a412e86e3e50b636c0
server/service/src/main/java/com/doumee/core/utils/DateUtil.java
@@ -1,11 +1,16 @@
package com.doumee.core.utils;
import java.math.BigDecimal;
import java.math.RoundingMode;
import java.sql.Timestamp;
import java.text.DateFormat;
import java.text.DateFormatSymbols;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.time.LocalDate;
import java.time.Period;
import java.time.ZoneId;
import java.util.Calendar;
import java.util.Date;
import java.util.Enumeration;
@@ -89,10 +94,12 @@
    /**
     * 得出两个日期之间的间隔小时
     *
     * @param fromDate
     * @param fromDate 靠前的时间
     *            格式为yyyy-MM-dd
     * @param toDate
     * @param toDate  靠后的时间
     *            格式为yyyy-MM-dd
     *                DateUtil.getBetweenHours(DateUtil.fromStringToDate("yyyy-MM-dd HH:mm:ss","2025-05-26 10:46:43"),
     *                 DateUtil.fromStringToDate("yyyy-MM-dd HH:mm:ss","2025-05-26 07:41:43")) 返回 -2小时
     * @return int
     */
    public static long getBetweenHours(Date fromDate, Date toDate) {
@@ -101,6 +108,33 @@
        try {
            m_intervalday = toDate.getTime() - fromDate.getTime();// 计算所得为微秒数
            m_intervalday = m_intervalday / 1000 / 60 / 60;// 计算所得的天数
            return m_intervalday + 1;
        } catch (Exception e) {
            return Integer.MIN_VALUE;
        }
    }
    public static long getBetweenMin(Date fromDate, Date toDate) {
        long m_intervalday = 0;// 初始化时间间隔的值为0
        // 使用的时间格式为yyyy-MM-dd
        try {
            m_intervalday = toDate.getTime() - fromDate.getTime();// 计算所得为微秒数
            m_intervalday = m_intervalday / 1000 / 60 ;// 计算所得的天数
            return m_intervalday + 1;
        } catch (Exception e) {
            return Integer.MIN_VALUE;
        }
    }
    public static long getBetweenDay(Date fromDate, Date toDate) {
        long m_intervalday = 0;// 初始化时间间隔的值为0
        // 使用的时间格式为yyyy-MM-dd
        try {
            m_intervalday = toDate.getTime() - fromDate.getTime();// 计算所得为微秒数
            m_intervalday = m_intervalday / 1000 / 60 / 60 / 24 ;// 计算所得的天数
            return m_intervalday + 1;
        } catch (Exception e) {
@@ -348,6 +382,8 @@
            throw e;
        }
    }
    /**
     * Descrption:取得当前日期,格式为:yyyy-MM-dd HH:mm:ss
@@ -882,95 +918,95 @@
     * @return 转换得到的日期
     */
    @SuppressWarnings("unchecked")
    public static Date stringToDate(String strDate, String oracleFormat) {
        if (strDate == null)
            return null;
        Hashtable<Integer, String> h = new Hashtable<Integer, String>();
        String javaFormat = new String();
        String s = oracleFormat.toLowerCase();
        if (s.indexOf("yyyy") != -1)
            h.put(new Integer(s.indexOf("yyyy")), "yyyy");
        else if (s.indexOf("yy") != -1)
            h.put(new Integer(s.indexOf("yy")), "yy");
        if (s.indexOf("mm") != -1)
            h.put(new Integer(s.indexOf("mm")), "MM");
        if (s.indexOf("dd") != -1)
            h.put(new Integer(s.indexOf("dd")), "dd");
        if (s.indexOf("hh24") != -1)
            h.put(new Integer(s.indexOf("hh24")), "HH");
        if (s.indexOf("mi") != -1)
            h.put(new Integer(s.indexOf("mi")), "mm");
        if (s.indexOf("ss") != -1)
            h.put(new Integer(s.indexOf("ss")), "ss");
        int intStart = 0;
        while (s.indexOf("-", intStart) != -1) {
            intStart = s.indexOf("-", intStart);
            h.put(new Integer(intStart), "-");
            intStart++;
        }
        intStart = 0;
        while (s.indexOf("/", intStart) != -1) {
            intStart = s.indexOf("/", intStart);
            h.put(new Integer(intStart), "/");
            intStart++;
        }
        intStart = 0;
        while (s.indexOf(" ", intStart) != -1) {
            intStart = s.indexOf(" ", intStart);
            h.put(new Integer(intStart), " ");
            intStart++;
        }
        intStart = 0;
        while (s.indexOf(":", intStart) != -1) {
            intStart = s.indexOf(":", intStart);
            h.put(new Integer(intStart), ":");
            intStart++;
        }
        if (s.indexOf("年") != -1)
            h.put(new Integer(s.indexOf("年")), "年");
        if (s.indexOf("月") != -1)
            h.put(new Integer(s.indexOf("月")), "月");
        if (s.indexOf("日") != -1)
            h.put(new Integer(s.indexOf("日")), "日");
        if (s.indexOf("时") != -1)
            h.put(new Integer(s.indexOf("时")), "时");
        if (s.indexOf("分") != -1)
            h.put(new Integer(s.indexOf("分")), "分");
        if (s.indexOf("秒") != -1)
            h.put(new Integer(s.indexOf("秒")), "秒");
        int i = 0;
        while (h.size() != 0) {
            Enumeration e = h.keys();
            int n = 0;
            while (e.hasMoreElements()) {
                i = ((Integer) e.nextElement()).intValue();
                if (i >= n)
                    n = i;
            }
            String temp = (String) h.get(new Integer(n));
            h.remove(new Integer(n));
            javaFormat = temp + javaFormat;
        }
        SimpleDateFormat df = new SimpleDateFormat(javaFormat);
        Date myDate = new Date();
        try {
            myDate = df.parse(strDate);
        } catch (Exception e) {
            // e.printStackTrace();
            return null;
        }
        return myDate;
    }
//    public static Date stringToDate(String strDate, String oracleFormat) {
//        if (strDate == null)
//            return null;
//        Hashtable<Integer, String> h = new Hashtable<Integer, String>();
//        String javaFormat = new String();
//        String s = oracleFormat.toLowerCase();
//        if (s.indexOf("yyyy") != -1)
//            h.put(new Integer(s.indexOf("yyyy")), "yyyy");
//        else if (s.indexOf("yy") != -1)
//            h.put(new Integer(s.indexOf("yy")), "yy");
//        if (s.indexOf("mm") != -1)
//            h.put(new Integer(s.indexOf("mm")), "MM");
//
//        if (s.indexOf("dd") != -1)
//            h.put(new Integer(s.indexOf("dd")), "dd");
//        if (s.indexOf("hh24") != -1)
//            h.put(new Integer(s.indexOf("hh24")), "HH");
//        if (s.indexOf("mi") != -1)
//            h.put(new Integer(s.indexOf("mi")), "mm");
//        if (s.indexOf("ss") != -1)
//            h.put(new Integer(s.indexOf("ss")), "ss");
//
//        int intStart = 0;
//        while (s.indexOf("-", intStart) != -1) {
//            intStart = s.indexOf("-", intStart);
//            h.put(new Integer(intStart), "-");
//            intStart++;
//        }
//
//        intStart = 0;
//        while (s.indexOf("/", intStart) != -1) {
//            intStart = s.indexOf("/", intStart);
//            h.put(new Integer(intStart), "/");
//            intStart++;
//        }
//
//        intStart = 0;
//        while (s.indexOf(" ", intStart) != -1) {
//            intStart = s.indexOf(" ", intStart);
//            h.put(new Integer(intStart), " ");
//            intStart++;
//        }
//
//        intStart = 0;
//        while (s.indexOf(":", intStart) != -1) {
//            intStart = s.indexOf(":", intStart);
//            h.put(new Integer(intStart), ":");
//            intStart++;
//        }
//
//        if (s.indexOf("年") != -1)
//            h.put(new Integer(s.indexOf("年")), "年");
//        if (s.indexOf("月") != -1)
//            h.put(new Integer(s.indexOf("月")), "月");
//        if (s.indexOf("日") != -1)
//            h.put(new Integer(s.indexOf("日")), "日");
//        if (s.indexOf("时") != -1)
//            h.put(new Integer(s.indexOf("时")), "时");
//        if (s.indexOf("分") != -1)
//            h.put(new Integer(s.indexOf("分")), "分");
//        if (s.indexOf("秒") != -1)
//            h.put(new Integer(s.indexOf("秒")), "秒");
//
//        int i = 0;
//        while (h.size() != 0) {
//            Enumeration e = h.keys();
//            int n = 0;
//            while (e.hasMoreElements()) {
//                i = ((Integer) e.nextElement()).intValue();
//                if (i >= n)
//                    n = i;
//            }
//            String temp = (String) h.get(new Integer(n));
//            h.remove(new Integer(n));
//
//            javaFormat = temp + javaFormat;
//        }
//        SimpleDateFormat df = new SimpleDateFormat(javaFormat);
//
//        Date myDate = new Date();
//        try {
//            myDate = df.parse(strDate);
//        } catch (Exception e) {
//            // e.printStackTrace();
//            return null;
//        }
//
//        return myDate;
//    }
    public static Date StringToDate(String DATE1) {
        DateFormat df = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
@@ -1298,7 +1334,7 @@
        calo.setTime(oldDate);
        caln.setTime(newDate);
        if(type==0||type==1){
            return    calculateDaysBetweenDates(caln, calo) ;
            return    calculateDaysBetweenDates(caln, calo)  + 1 ;
        }else if(type==2){
            int day = caln.get(Calendar.DATE);
@@ -2995,6 +3031,21 @@
        return calendar.getTime();
    }
    /**
     * 获取指定日期的下个月第一天
     * @param date
     * @return
     */
    public static Date getNextMonthFirst(Date date){
        Calendar calendar = Calendar.getInstance();
        calendar.setTime(date);
        calendar.add(Calendar.MONTH, 1); // 将日历的月份增加1
        calendar.set(Calendar.DAY_OF_MONTH, 1); // 设置为下个月的第一天
        return calendar.getTime();
    }
    public static String afterDateToStr(Integer days){
        Date date = new Date();
@@ -3012,6 +3063,10 @@
    public static String getLongDate(Date date) {
        return DateToString(date, "yyyyMMddHHmmss");
    }
    public static String getLongDateTime(Date date) {
        return DateToString(date, "yyyy-MM-dd HH:mm:ss");
    }
    public static String DateToString(Date date, String dateStyle) {
@@ -3058,7 +3113,25 @@
        return cal.getTime();
    }
    /**
     * 获取某个时间X分钟后的时间
     * @param minutes
     * @param date
     * @return
     */
    public static Date afterMinutesByDate(Integer minutes,Date date){
        Calendar cal = Calendar.getInstance();
        cal.setTime(date);
        cal.add(Calendar.MINUTE,minutes);
        return cal.getTime();
    }
    public static Date afterDayByDate(Integer days,Date date){
        Calendar cal = Calendar.getInstance();
        cal.setTime(date);
        cal.add(Calendar.DATE,days);
        return cal.getTime();
    }
    /**
     * 计算多少自然年/月/日后的日期
     * @param startDate 开始日期
@@ -3109,25 +3182,59 @@
    }
    public static void main(String[] args) {
//       System.out.println(DateUtil.DateToStr(DateUtil.afterDateByType(
//               DateUtil.stringToDate("2024-02-01","yyyy-MM-dd")
//               ,1,1),"yyyy-MM-dd HH:mm:ss"));
        System.out.println( DateUtil.daysBetweenDates(DateUtil.stringToDate("2024-02-29","yyyy-MM-dd"),
                DateUtil.stringToDate("2024-02-01","yyyy-MM-dd"))
        );
        System.out.println(DateUtil.calculateBetween(DateUtil.StringToDate("2024-02-29 23:59:59"),DateUtil.StringToDate("2024-02-01 00:00:00"),0));
//        Calendar calo = Calendar.getInstance();
//        Calendar caln = Calendar.getInstance(); // ,"yyyy-MM-dd HH:mm:ss"
//        caln.setTime(DateUtil.StringToDate("2024-02-29 23:59:59"));
//        calo.setTime(DateUtil.StringToDate("2024-02-01 00:00:00"));
//        System.out.println( DateUtil.calculateDaysBetweenDates(calo,caln));
    /**
     * 拼接日期数据
     * @param date
     * @param optType   1:每日开始 2:每日结束 3:昨日结束
     * @return
     */
    public static Date getMontageDate(Date date ,Integer optType) {
        String strShortDate = DateUtil.dateToString(date,"yyyy-MM-dd");
        if(optType.equals(1)){
            return DateUtil.StringToDate(strShortDate +" 00:00:00");
        }else if(optType.equals(2)){
            return DateUtil.StringToDate(strShortDate +" 23:59:59");
        }else if(optType.equals(3)){
            strShortDate = DateUtil.dateToString(DateUtil.getDateBetween(date,-1),"yyyy-MM-dd");
            return DateUtil.StringToDate(strShortDate +" 23:59:59");
        }else{
            return null;
        }
    }
    public static void main(String[] args) throws Exception{
        System.out.println(DateUtil.DateToStr(
                DateUtil.afterDateByType(new Date(),1,-11),"yyyy-MM")
        );
//
//        System.out.println(DateUtil.getBetweenHours(DateUtil.fromStringToDate("yyyy-MM-dd HH:mm:ss","2025-05-26 10:46:43"),
//                DateUtil.fromStringToDate("yyyy-MM-dd HH:mm:ss","2025-05-26 07:41:43")));
//        ;
//        System.out.println(DateUtil.getLongDateTime(new Date()));;
    }
    /**
     * 获取相差的月数
     * @param sDate
     * @param eDate
     * @return
     */
    public static Integer getDifferenceMonths(Date sDate ,Date eDate) {
        LocalDate startDate = sDate.toInstant()
                .atZone(ZoneId.systemDefault())
                .toLocalDate();
        LocalDate endDate = eDate.toInstant()
                .atZone(ZoneId.systemDefault())
                .toLocalDate();
//        LocalDate startDate= LocalDate.of(2021,2,28);
//        LocalDate endDate =LocalDate.of(2022,4,5);
        Period period = Period.between(endDate,startDate);
        int months = period.getYears()* 12 + period.getMonths();
        return months + 1;
    }
}