From 148af6b2f57be264c84d0991237fbd7ddea491a4 Mon Sep 17 00:00:00 2001
From: yujian <yujian@123.com>
Date: 星期一, 04 十一月 2019 09:55:55 +0800
Subject: [PATCH] Merge branch 'div' of ssh://193.112.35.168:29418/fanli-server into div

---
 utils/src/main/java/org/yeshi/utils/DateUtil.java |  332 ++++++++++++++++++++++++++++++++++++++++---------------
 1 files changed, 240 insertions(+), 92 deletions(-)

diff --git a/utils/src/main/java/org/yeshi/utils/DateUtil.java b/utils/src/main/java/org/yeshi/utils/DateUtil.java
index 24148cf..e8f4028 100644
--- a/utils/src/main/java/org/yeshi/utils/DateUtil.java
+++ b/utils/src/main/java/org/yeshi/utils/DateUtil.java
@@ -7,6 +7,8 @@
 import java.util.Date;
 import java.util.List;
 
+import org.yeshi.utils.entity.DateInfo;
+
 public class DateUtil {
 
 	public static String dateDiff(String startTime, String endTime) {
@@ -37,7 +39,7 @@
 
 	public static String dateDiff2(Date startTime, Date endTime) throws Exception {
 
-		String datatime = 0 + "澶�" + 0 + "灏忔椂" + 0 + "鍒嗛挓";
+		String datatime = "0鍒�";
 
 		long nm = 1000 * 60;// 涓�鍒嗛挓鐨勬绉掓暟
 		long nh = 1000 * 60 * 60;// 涓�灏忔椂鐨勬绉掓暟
@@ -45,26 +47,56 @@
 
 		// 鑾峰緱涓や釜鏃堕棿鐨勬绉掓椂闂村樊寮�
 		long diff = endTime.getTime() - startTime.getTime();
-
 		long day = diff / nd;// 璁$畻宸灏戝ぉ
 		long hour = diff % nd / nh;// 璁$畻宸灏戝皬鏃�
 		long min = diff % nd % nh / nm;// 璁$畻宸灏戝垎閽�
 
-		datatime = day + "澶�" + hour + "灏忔椂" + min + "鍒嗛挓";
-
+		if (day > 0) {
+			datatime = day + "澶�" + hour + "鏃�" + min + "鍒�";
+		} else {
+			if (hour > 0) {
+				datatime = hour + "鏃�" + min + "鍒�";
+			} else {
+				if (min < 0)
+					min = 0;
+				datatime = min + "鍒�";
+			}
+		}
 		return datatime;
 	}
-	
+
+	public static DateInfo dateDiff3(long startTime, long endTime) throws Exception {
+		long nm = 1000 * 60;// 涓�鍒嗛挓鐨勬绉掓暟
+		long nh = 1000 * 60 * 60;// 涓�灏忔椂鐨勬绉掓暟
+		long nd = 1000 * 24 * 60 * 60;// 涓�澶╃殑姣鏁�
+
+		// 鑾峰緱涓や釜鏃堕棿鐨勬绉掓椂闂村樊寮�
+		long diff = endTime - startTime;
+
+		int day = (int) (diff / nd);// 璁$畻宸灏戝ぉ
+		long hour = diff % nd / nh;// 璁$畻宸灏戝皬鏃�
+		long minute = diff % nd % nh / nm;// 璁$畻宸灏戝垎閽�
+		long second = (diff / 1000 - day * 24 * 60 * 60 - hour * 60 * 60 - minute * 60); // 璁$畻宸灏戠
+
+		DateInfo dateInfo = new DateInfo();
+		dateInfo.setDay(day);
+		dateInfo.setHour(hour);
+		dateInfo.setMinute(minute);
+		dateInfo.setSecond(second);
+		return dateInfo;
+	}
+
 	/**
 	 * 閫氳繃鏃堕棿绉掓绉掓暟鍒ゆ柇涓や釜鏃堕棿鐨勯棿闅�
-     * @param date1
-     * @param date2
-     * @return
-     */
-    public static int differentDaysByMillisecond(Date start, Date end) {
-    	return (int) ((end.getTime() - start.getTime()) / (1000*3600*24));
-    }
-	
+	 * 
+	 * @param date1
+	 * @param date2
+	 * @return
+	 */
+	public static int differentDaysByMillisecond(Date start, Date end) {
+		return (int) ((end.getTime() - start.getTime()) / (1000 * 3600 * 24));
+	}
+
 	public String transferLongToDate(String dateFormat, Long millSec) {
 		SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
 		Date date = new Date(millSec);
@@ -104,110 +136,196 @@
 			return false;
 		}
 	}
-	
+
+	/**
+	 * 鍒ゆ柇鏄惁鍚屼竴涓湀
+	 * 
+	 * @param date1
+	 * @param date2
+	 * @return
+	 */
+	public static boolean isSameMonth(Date date1, Date date2) {
+		Calendar calendar1 = Calendar.getInstance();
+		calendar1.setTime(date1);
+		Calendar calendar2 = Calendar.getInstance();
+		calendar2.setTime(date2);
+		int year1 = calendar1.get(Calendar.YEAR);
+		int year2 = calendar2.get(Calendar.YEAR);
+		int month1 = calendar1.get(Calendar.MONTH);
+		int month2 = calendar2.get(Calendar.MONTH);
+		System.out.println(year1 + "  " + month1);
+		System.out.println(year2 + "  " + month2);
+		return calendar1.get(Calendar.YEAR) == calendar2.get(Calendar.YEAR)
+				&& calendar1.get(Calendar.MONTH) == calendar2.get(Calendar.MONTH);
+	}
+
 	/**
 	 * 鎸囧畾鏃ユ湡鍔犱笂澶╂暟鍚庣殑鏃ユ湡
 	 * 
-	 * @param num
-	 *            澧炲姞鐨勫ぉ鏁�
-	 * @param nowDate
-	 *            鍒涘缓鏃堕棿
+	 * @param num     澧炲姞鐨勫ぉ鏁�
+	 * @param nowDate 鍒涘缓鏃堕棿
 	 * @return
 	 * @throws ParseException
 	 */
 	public static String plusDay(int num, String nowDate) throws ParseException {
 		SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
 		Date currdate = format.parse(nowDate);
-	
+
 		Calendar ca = Calendar.getInstance();
 		ca.setTime(currdate);
 		ca.add(Calendar.DATE, num);
-		
+
 		return format.format(ca.getTime());
 	}
-	
-	
+
 	/**
 	 * 鎸囧畾鏃ユ湡鍔犱笂澶╂暟鍚庣殑鏃ユ湡
 	 * 
-	 * @param num
-	 *            澧炲姞鐨勫ぉ鏁�
-	 * @param nowDate
-	 *            鍒涘缓鏃堕棿
+	 * @param num     澧炲姞鐨勫ぉ鏁�
+	 * @param nowDate 鍒涘缓鏃堕棿
 	 * @return
 	 * @throws ParseException
 	 */
 	public static String plusDay(int num, Date currdate) throws ParseException {
 		SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
-	
+
 		Calendar ca = Calendar.getInstance();
 		ca.setTime(currdate);
 		ca.add(Calendar.DATE, num);
-		
+
 		return format.format(ca.getTime());
 	}
-	
+
+	/**
+	 * 鎸囧畾鏃ユ湡鍔犱笂澶╂暟鍚庣殑鏃ユ湡
+	 * 
+	 * @param num     澧炲姞鐨勫ぉ鏁�
+	 * @param nowDate 鍒涘缓鏃堕棿
+	 * @return
+	 * @throws ParseException
+	 */
+	public static Date plusDayDate(int num, Date currdate) {
+		Calendar ca = Calendar.getInstance();
+		ca.setTime(currdate);
+		ca.add(Calendar.DATE, num);
+		return ca.getTime();
+	}
+
 	/**
 	 * 鎸囧畾鏃ユ湡鍑忓幓澶╂暟鍚庣殑鏃ユ湡
 	 * 
-	 * @param num
-	 *            鍑忓幓鐨勫ぉ鏁�
-	 * @param nowDate
-	 *            鍒涘缓鏃堕棿
+	 * @param num     鍑忓幓鐨勫ぉ鏁�
+	 * @param nowDate 鍒涘缓鏃堕棿
 	 * @return
 	 * @throws ParseException
 	 */
 	public static String reduceDay(int num, String nowDate) throws ParseException {
 		SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
 		Date currdate = format.parse(nowDate);
-	
+
 		Calendar ca = Calendar.getInstance();
 		ca.setTime(currdate);
 		ca.add(Calendar.DATE, -num); // 鏃ユ湡鍑� 濡傛灉涓嶅鍑忎細灏嗘湀鍙樺姩
-		
+
 		return format.format(ca.getTime());
 	}
-	
-	  /**
-     * 璁$畻涓や釜鏃ユ湡涔嬮棿鐩稿樊鐨勫ぉ鏁�  
-     * @param smdate 杈冨皬鐨勬椂闂� 
-     * @param bdate  杈冨ぇ鐨勬椂闂� 
-     * @return 鐩稿樊澶╂暟 
-     * @throws ParseException  
-     * calendar 瀵规棩鏈熻繘琛屾椂闂存搷浣�
-     * getTimeInMillis() 鑾峰彇鏃ユ湡鐨勬绉掓樉绀哄舰寮�
-     */
-    public static int daysBetween(Date smdate,Date bdate) throws ParseException    
-    {    
-        Calendar cal = Calendar.getInstance();
-        cal.setTime(smdate);
-        long time1 = cal.getTimeInMillis();
-        cal.setTime(bdate);
-        long time2 = cal.getTimeInMillis();      
-        long between_days=(time2-time1)/(1000*3600*24);  
-        return Integer.parseInt(String.valueOf(between_days));           
-    }
-    
-    /**
-     * 瀛楃涓叉棩鏈熸牸寮忕殑璁$畻
-     * @param smdate
-     * @param bdate
-     * @return
-     * @throws ParseException
-     */
-    public static int daysBetween(String smdate,String bdate) throws ParseException{  
-        SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd");  
-        Calendar cal = Calendar.getInstance();    
-        cal.setTime(sdf.parse(smdate));    
-        long time1 = cal.getTimeInMillis();                 
-        cal.setTime(sdf.parse(bdate));    
-        long time2 = cal.getTimeInMillis();         
-        long between_days=(time2-time1)/(1000*3600*24);  
-        return Integer.parseInt(String.valueOf(between_days));     
-    } 
-	
+
+	/**
+	 * 鎸囧畾鏃ユ湡鍑忓幓澶╂暟鍚庣殑鏃ユ湡
+	 * 
+	 * @param num     鍑忓幓鐨勫ぉ鏁�
+	 * @param nowDate 鍒涘缓鏃堕棿
+	 * @return
+	 * @throws ParseException
+	 */
+	public static Date reduceDay(int num, Date date) throws ParseException {
+		// 璁剧疆瑕佽幏鍙栧埌浠�涔堟牱鐨勬椂闂�
+		SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
+		// 鑾峰彇String绫诲瀷鐨勬椂闂�
+		String date_str = format.format(date);
+		Date currdate = format.parse(date_str);
+
+		Calendar ca = Calendar.getInstance();
+		ca.setTime(currdate);
+		ca.add(Calendar.DATE, -num); // 鏃ユ湡鍑� 濡傛灉涓嶅鍑忎細灏嗘湀鍙樺姩
+
+		return ca.getTime();
+	}
+
+	/**
+	 * 鎸囧畾鏃ユ湡鍑忓幓澶╂暟鍚庣殑鏃ユ湡
+	 * 
+	 * @param num     鍑忓幓鐨勫ぉ鏁�
+	 * @param nowDate 鍒涘缓鏃堕棿
+	 * @return
+	 * @throws ParseException
+	 */
+	public static String reduceDayTostring(int num, Date date) throws ParseException {
+		// 璁剧疆瑕佽幏鍙栧埌浠�涔堟牱鐨勬椂闂�
+		SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
+		// 鑾峰彇String绫诲瀷鐨勬椂闂�
+		String date_str = format.format(date);
+		Date currdate = format.parse(date_str);
+
+		Calendar ca = Calendar.getInstance();
+		ca.setTime(currdate);
+		ca.add(Calendar.DATE, -num); // 鏃ユ湡鍑� 濡傛灉涓嶅鍑忎細灏嗘湀鍙樺姩
+		return format.format(ca.getTime());
+	}
+
+	/**
+	 * 璁$畻涓や釜鏃ユ湡涔嬮棿鐩稿樊鐨勫ぉ鏁�
+	 * 
+	 * @param smdate 杈冨皬鐨勬椂闂�
+	 * @param bdate  杈冨ぇ鐨勬椂闂�
+	 * @return 鐩稿樊澶╂暟
+	 * @throws ParseException calendar 瀵规棩鏈熻繘琛屾椂闂存搷浣� getTimeInMillis() 鑾峰彇鏃ユ湡鐨勬绉掓樉绀哄舰寮�
+	 */
+	public static int daysBetween(Date minDate, Date maxDate) throws ParseException {
+		Calendar cal = Calendar.getInstance();
+		cal.setTime(minDate);
+		long minTime = cal.getTimeInMillis();
+		cal.setTime(maxDate);
+		long maxTime = cal.getTimeInMillis();
+		long between_days = (maxTime - minTime) / (1000 * 3600 * 24);
+		return Integer.parseInt(String.valueOf(between_days));
+	}
+
+	/**
+	 * 瀛楃涓叉棩鏈熸牸寮忕殑璁$畻
+	 * 
+	 * @param smdate
+	 * @param bdate
+	 * @return 鍗曚綅澶╂暟
+	 * @throws ParseException
+	 */
+	public static int daysBetween2(Date minDate, Date maxDate) throws ParseException {
+		SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
+		return daysBetween(sdf.format(minDate), sdf.format(maxDate));
+	}
+
+	/**
+	 * 瀛楃涓叉棩鏈熸牸寮忕殑璁$畻
+	 * 
+	 * @param smdate
+	 * @param bdate
+	 * @return
+	 * @throws ParseException
+	 */
+	public static int daysBetween(String minDate, String maxDate) throws ParseException {
+		SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
+		Calendar cal = Calendar.getInstance();
+		cal.setTime(sdf.parse(minDate));
+		long minTime = cal.getTimeInMillis();
+		cal.setTime(sdf.parse(maxDate));
+		long maxTime = cal.getTimeInMillis();
+		long between_days = (maxTime - minTime) / (1000 * 3600 * 24);
+		return Integer.parseInt(String.valueOf(between_days));
+	}
+
 	/**
 	 * 杩斿洖涓棿鏃ユ湡
+	 * 
 	 * @param startTime
 	 * @param endTime
 	 * @return
@@ -233,23 +351,53 @@
 		}
 		return listDate;
 	}
-	
-	
-	/**
-     * @param args
-     * @throws ParseException
-     * format() 瀵规棩鏈熻繘琛屾牸寮忓寲澶勭悊
-     * parse() 灏嗘棩鏈熻缃负date绫诲瀷
-     */
-    public static void main(String[] args) throws ParseException {  
-        // TODO Auto-generated method stub  
-        SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");  
-        Date d1=sdf.parse("2016-09-08 00:00:00");  
-        Date d2=sdf.parse("2016-09-08 00:00:00");
-        
-        System.out.println(daysBetween(d1,d2));  
-        System.out.println(daysBetween("2016-09-08 10:10:10","2016-09-29 00:00:00")); 
-    }  
 
-	
+	/**
+	 * 闅忔満鍑忓幓鍑犲垎閽�
+	 * 
+	 * @param date
+	 * @param min  闅忔満娣诲姞鐨勫垎閽熸暟
+	 * @return
+	 */
+	public static Date reduceRandomMinute(Date date, int min) {
+		long rand = (long) (Math.random() * 1000 * 60 * min);
+		long time = date.getTime() - rand;
+		return new Date(time);
+	}
+
+	/**
+	 * 璁$畻涓ゆ椂闂存湀宸�
+	 * 
+	 * @param startDate <String>
+	 * @param endDate <String>
+	 * @return int
+	 * @throws ParseException
+	 */
+	public static int getMonthSpace(String startDate, String endDate) throws ParseException {
+        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM");
+        return getMonthSpace(sdf.parse(startDate), sdf.parse(endDate));
+	}
+
+	/**
+	 * 璁$畻涓ゆ椂闂存湀宸�
+	 * 
+	 * @param startDate <String>
+	 * @param endDate <String>
+	 * @return int
+	 * @throws ParseException
+	 */
+	public static int getMonthSpace(Date startDate, Date endDate) {
+		Calendar start = Calendar.getInstance();
+		Calendar end = Calendar.getInstance();
+		start.setTime(startDate);
+		end.setTime(endDate);
+		int result = end.get(Calendar.MONTH) - start.get(Calendar.MONTH);
+        int month = (end.get(Calendar.YEAR) - start.get(Calendar.YEAR)) * 12;
+		return Math.abs(month + result);
+	}
+
+	public static void main(String[] args) throws ParseException {
+        System.out.println(getMonthSpace("2012-02", "2013-01"));   
+    }
+
 }
\ No newline at end of file

--
Gitblit v1.8.0