java比較時間
問題描述
String date1 = “2017-04-06”;String start = '2017-04';String end = '2017-06';java 計算data1是否在start和end之間。start和end即表示的是四月到六月
問題解答
回答1:如果你沒用Java8:
import java.text.ParseException;import java.text.SimpleDateFormat;import java.util.Date;public class Main { public static void main(String[] args) throws ParseException {String date1 = '2017-06-06';String start = '2017-04';String end = '2017-06';Date d1 = new SimpleDateFormat('yyyy-MM-dd').parse(date1);Date dStart = new SimpleDateFormat('yyyy-MM').parse(start);Calendar c = Calendar.getInstance();c.setTime(new SimpleDateFormat('yyyy-MM').parse(end));c.add(Calendar.MONTH, 1);Date dEnd = c.getTime();if (d1.after(dStart) && d1.before(dEnd)) { System.out.println('true');} else { System.out.println('false');} }}回答2:
我看前面已經有人說到Java8了...不過這個寫法是有點尷尬...思路大家基本一樣...
給的start時間要變為當前月的第一天
給的end時間要變為當前月的最后一天
關鍵是如何變的問題...Java8的時間是有現成的API可以調用的...不需要parse這種方式...變成第一天還好,變成最后一天有諸多的判斷...
代碼如下,按照所給條件,寫了一個isBetween方法
public static boolean isBetween(String date, String start, String end){// 把start轉化為start所在月份的第一天LocalDate startDate = LocalDate.now().with(YearMonth.parse(start)).with(TemporalAdjusters.firstDayOfMonth());// 把end轉化為end所在月份的最后一天LocalDate endDate = LocalDate.now().with(YearMonth.parse(end)).with(TemporalAdjusters.lastDayOfMonth());// 把date轉化為LocalDateLocalDate currentDate = LocalDate.parse(date);return currentDate.isAfter(startDate) && currentDate.isBefore(endDate); }
簡單解釋一下...yyyy-mm這種年月的形式在Java8中已經有新的類來處理,這就是YearMonth(它是一個TemporalAdjuster的實現類),根據LocalDate(它是一個Temporal的實現類)的with方法,其實是Temporal接口的with方法,這里涉及到Java8的新時間API的設計,with方法簽名如下
含義即是:一個Temporal對象可以根據一個TemporalAdjuster對象進行調整
所以結合到上面寫的代碼,思路如下
隨意取了當前時間LocalDate A
把A根據傳入的YearMonth進行修改(調用with方法),即調整時間的年和月,得到時間B
把B再根據一個調整器TemporalAdjuster(TemporalAdjusters.firstDayOfMonth),調整時間的日,得到最后的時間
其實時間調整,在TemporalAdjusters中已經封裝了不少常用的了...用起來也簡單直白好用的,可以關注這個類
最后,提供一個我以前自己簡單連的Java8新時間API的一些關系,跟著這些關系可以再看看具體類,捋捋關系,會發現新時間API不但好用還很強大
如果你用上了 Java8:
import java.time.LocalDate;public class What { public static void main(String[] args) throws Exception {String date1 = '2017-04-06';String start = '2017-04';String end = '2017-06';LocalDate date = LocalDate.parse(date1);LocalDate startDate = LocalDate.parse(start + '-01');LocalDate endDate = LocalDate.parse(end + '-01');endDate = endDate.plusDays(endDate.getMonth().maxLength());if (date.isAfter(startDate) && date.isBefore(endDate)) { System.out.println('data1 在 start 和 end 之間');} else { System.out.println('data1 不在 start 和 end 之間');} } }回答4:
如果你沒用Java8但用了Joda-time:
public boolean between(String date){ String start = '2017-04'; String end = '2017-06'; try {return DateTime.parse(date).isAfter(DateTime.parse(start).withDayOfMonth(1).toInstant()) && DateTime.parse(date).isBefore(DateTime.parse(end).plusMonths(1).withDayOfMonth(1).minusDays(1).toInstant()); }catch (Exception e){return false; }}回答5:
end要轉換成這個月的最后一天,比如說2017-06-30;
如果格式確定為yyyy-mm或yyyy-mm-dd,那么用date.compareTo(start) >= 0 && date.compareTo(end) < 0就可以了;
如果有不規范的格式,比如2017-4-6,要么轉換成規范的格式,要么都轉換成Date或long(Date本質就是long),再進行比較。
相關文章:
1. 一個mysql聯表查詢的問題2. 運行python程序時出現“應用程序發生異常”的內存錯誤?3. html5 - iOS的webview加載出來的H5網頁,怎么修改html標簽select的樣式字體?4. java - 我現在一個servlet中有調用socket訪問,作為socket的客戶端,5. python 如何實現PHP替換圖片 鏈接6. python如何不改動文件的情況下修改文件的 修改日期7. 主從備份 - 跪求mysql 高可用主從方案8. javascript - git clone 下來的項目 想在本地運行 npm run install 報錯9. mysql主從 - 請教下mysql 主動-被動模式的雙主配置 和 主從配置在應用上有什么區別?10. mysql - 一個表和多個表是多對多的關系,該怎么設計
