From 142bcc9b22f48a8a2098a66b2964fe10c97c6fe8 Mon Sep 17 00:00:00 2001 From: k94314517 <8417338+k94314517@user.noreply.gitee.com> Date: 星期二, 20 五月 2025 11:19:49 +0800 Subject: [PATCH] git ch --- server/service/src/main/java/com/doumee/core/utils/DateUtil.java | 417 +++++++++++++++++++++++++++++++++++++++++++++------------- 1 files changed, 320 insertions(+), 97 deletions(-) diff --git a/server/service/src/main/java/com/doumee/core/utils/DateUtil.java b/server/service/src/main/java/com/doumee/core/utils/DateUtil.java index 7942d79..6860dfb 100644 --- a/server/service/src/main/java/com/doumee/core/utils/DateUtil.java +++ b/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; @@ -101,6 +106,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 +380,8 @@ throw e; } } + + /** * Descrption:鍙栧緱褰撳墠鏃ユ湡,鏍煎紡涓�:yyyy-MM-dd HH:mm:ss @@ -882,95 +916,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"); @@ -1291,6 +1325,59 @@ return days; } + + public static int calculateBetween(Date newDate, Date oldDate,Integer type){ + Calendar calo = Calendar.getInstance(); + Calendar caln = Calendar.getInstance(); + calo.setTime(oldDate); + caln.setTime(newDate); + if(type==0||type==1){ + return calculateDaysBetweenDates(caln, calo) + 1 ; + }else if(type==2){ + + int day = caln.get(Calendar.DATE); + if(day == 1){ + return calculateMonthsBetweenDates(caln, calo) + 1; + }else{ + return calculateMonthsBetweenDates(caln, calo); + } + + }else if(type==3){ + return calculateYearsBetweenDates(caln, calo) + 1; + } + return -1; + } + + + + public static int calculateDaysBetweenDates(Calendar startDate, Calendar endDate) { + long timeDiffInMillis = Math.abs(endDate.getTimeInMillis() - startDate.getTimeInMillis()); + return (int)(timeDiffInMillis / (24 * 60 * 60 * 1000)); + } + + public static int calculateMonthsBetweenDates(Calendar startDate, Calendar endDate) { + int yearDiff = endDate.get(Calendar.YEAR) - startDate.get(Calendar.YEAR); + int monthDiff = endDate.get(Calendar.MONTH) - startDate.get(Calendar.MONTH); + if (monthDiff < 0 || (monthDiff == 0 && endDate.get(Calendar.DAY_OF_MONTH) < startDate.get(Calendar.DAY_OF_MONTH))) { + yearDiff--; + monthDiff += 12; + } + return yearDiff * 12 + monthDiff; + } + + public static int calculateYearsBetweenDates(Calendar startDate, Calendar endDate) { + int yearDiff = endDate.get(Calendar.YEAR) - startDate.get(Calendar.YEAR); + if (yearDiff > 0 && (startDate.get(Calendar.MONTH) >= endDate.get(Calendar.MONTH) || + (startDate.get(Calendar.MONTH) == endDate.get(Calendar.MONTH) && startDate.get(Calendar.DAY_OF_MONTH) <= endDate.get(Calendar.DAY_OF_MONTH)))) { + yearDiff--; + } else if (yearDiff < 0 && (startDate.get(Calendar.MONTH) <= endDate.get(Calendar.MONTH) || + (startDate.get(Calendar.MONTH) == endDate.get(Calendar.MONTH) && startDate.get(Calendar.DAY_OF_MONTH) >= endDate.get(Calendar.DAY_OF_MONTH)))) { + yearDiff++; + } + return yearDiff; + } + + /** * 鍙栧緱涓庡師鏃ユ湡鐩稿樊涓�瀹氬ぉ鏁扮殑鏃ユ湡锛岃繑鍥濪ate鍨嬫棩鏈� @@ -2748,13 +2835,6 @@ return sdfLongTimePlus.parse(sdfLongTimePlus.format(date)); } - public static void main(String[] args) { - try { - System.out.println(RandomStringUtils.randomNumeric(3)); - } catch (Exception ex) { - ex.printStackTrace(); - } - } /** * @@ -2859,6 +2939,7 @@ return nowDateString; } + /** * @ author zhangyong @ 鑾峰彇褰撴湀鐨勭涓�澶╋紝2009-05-01 */ @@ -2910,9 +2991,14 @@ return w; } - public static Long twoDaysBetween(Date beginDate, Date endDate) throws ParseException { + public static Long twoDaysBetween(Date beginDate, Date endDate) { long minute = (endDate.getTime() - beginDate.getTime()) / (60 * 1000); return minute; + } + + public static Integer daysBetweenDay(Date beginDate, Date endDate) { + long day = (endDate.getTime() - beginDate.getTime()) / (60 * 1000 * 60 * 24); + return Math.toIntExact(day); } /** @@ -2943,6 +3029,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(); @@ -2960,6 +3061,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) { @@ -3005,4 +3110,122 @@ cal.add(Calendar.MINUTE,minutes); 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 寮�濮嬫棩鏈� + * @param type 0=鏃ワ紱1=鏈堬紱2=骞达紱 + * @param cycle 鍛ㄦ湡 X鏈� + * @return + */ + public static Date afterDateByType(Date startDate,Integer type,Integer cycle){ + Calendar calendar = Calendar.getInstance(); + calendar.setTime(startDate); + if(type==0){ + calendar.add(Calendar.DATE, cycle); + }else if(type==1){ + calendar.add(Calendar.MONTH, cycle); + }else if(type == 2) { + calendar.add(Calendar.YEAR, cycle); + } + return calendar.getTime(); + } + + + + public static Integer monthDays(Date date){ + Calendar calendar = Calendar.getInstance(); + calendar.setTime(date); + // 鑾峰彇褰撳墠骞翠唤銆佹湀浠斤紙娉ㄦ剰鏈堜唤浠�0寮�濮嬭绠楋級 + int year = calendar.get(Calendar.YEAR); + int month = calendar.get(Calendar.MONTH) + 1; + // 鏍规嵁骞翠唤鍜屾湀浠藉垽鏂棸骞存儏鍐� + boolean isLeapYear = (year % 4 == 0 && year % 100 != 0) || (year % 400 == 0); + + // 鏍规嵁涓嶅悓鏈堜唤璁惧畾姣忎釜鏈堢殑澶╂暟 + switch (month) { + case 2: + if (isLeapYear) { + return 29; + } else { + return 28; + } + case 4: + case 6: + case 9: + case 11: + return 30; + default: + return 31; + } + } + + + /** + * 鎷兼帴鏃ユ湡鏁版嵁 + * @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.StringToDate("2025-05-16 13:49:40").getTime()); +// 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; + } + + + } \ No newline at end of file -- Gitblit v1.9.3