100个Java工具类之75:日期处理小霸王DateUtils

createh52个月前 (03-16)技术教程10

为了简化复杂的日期处理逻辑,Apache Commons Lang3提供了一系列使用方法,满足我们日期比较、解析、格式化等多样化的处理需求,学会使用此类,基本上就掌握了日期格式的使用。



一、日期格式化

// 创建当前时间的Date对象
Date date = new Date();
// 格式化日期
String dateString = DateUtils.formatDate(date, "yyyy-MM-dd HH:mm:ss");
System.out.println("日期: " + dateString);
输出:日期:2025-01-14 17:19:02


二、日期解析

String dateStr = "2024-01-14 17:90:99";
Date parsedDate = DateFormatUtils.parse(dateStr, "yyyy-MM-dd HH:mm:ss");
boolean isToday = DateUtils.isSameDay(parsedDate, new Date());
System.out.println("日期: " + parsedDate);
System.out.println("Is the parsed date today? " + isToday);
输出:
日期: Sun Jan 14 17:00:00 CET 2024
是否当前日期? false



三、日期比较

Calendar calendar = Calendar.getInstance();
calendar.set(2025, Calendar.JANUARY, 14);
Date date1 = calendar.getTime();
calendar.add(Calendar.DAY_OF_MONTH, 1);
Date date2 = calendar.getTime();
System.out.println("同一天么? " + DateUtils.isSameDay(date1, date2));
System.out.println("同一年么? " + DateUtils.isSameYear(date1, date2));
输出:
同一天么?false
同一年么?true

四、日期舍入

Date date = new Date();
Date newDate = DateUtils.round(date, Calendar.MINUTE);
System.out.println("现在的时间是: " + date);
System.out.println("舍入后日期是: " + newDate);
输出:
现在的时间是: Tue Jan 14 17:27:30 CST 2025
舍入后日期是: Tue Jan 14 17:28:00 CST 2025



五、日期截断

Date date = new Date();
// 截断到日
Date today = DateUtils.truncate(date, Calendar.DAY_OF_MONTH);
System.out.println("今日: " + today);
// 截断到小时
Date hour = DateUtils.truncate(date, Calendar.HOUR_OF_DAY);
System.out.println("今时: " + hour);
输出:
今日: Wed Jan 14 00:00:00 CST 2025
今时: Wed Jan 14 17:00:00 CST 2025

以上就是今天分享的全部内容,码字不易,不喜勿喷。


相关文章

java 判断Date是上午还是下午

我要用Java生成表格统计信息,如下图所示:所以就诞生了本文的内容。在 Java 里,判断 Date 对象代表的时间是上午还是下午有多种方式,下面为你详细介绍不同的实现方法。方式一:使用java.ut...

吊打面试官(十一)--Java语言中日期处理相关问题总结

导读在Java中,日期处理是必然遇到的场景,也是问题较多的场景。下面我们将收集的日期问题场景做一个汇总。祝大家面试必过,吊打面试官。让我们0帧起手,开始说具体问题。1. 日期格式化大小写问题问题描述:...

SpringBoot 日期格式化的两种方式

在Spring Boot中处理日期格式化是一个常见的需求,涉及数据库存储、接口参数传递、序列化等场景。以下是综合多个实践和最佳方案的总结:一、全局日期格式化配置通过配置文件统一设置全局日期格式,适用...

玩转MySQL的时间类型:Date、DateTime、TimeStamp、Time

Mysql时间类型介绍在MySQL中,有四种不同的时间类型:DATE、DATETIME、TIMESTAMP和TIME。它们分别表示不同精度和范围的时间。DATE类型DATE类型用于存储日期,格式为'Y...

Java编程的那些屎山代码分析之一

在编程行业干过这么多年,已经学会了从代码看人,代码会告诉我们,这个人在这一行能否吃饱饭,能吃到多少肉。以下是个人总结的一些代码习惯问题和优化,单独一个也许不起眼,但堆积起来,就让一个项目代码变成一座屎...

日期和时间,你真的会输入吗?

日期和时间是Excel中一种特殊类型的数据,有关日期和时间的计算在各个领域中都有非常广泛的应用。以下讲解日期和时间类数据的特点及计算方法,以及日期与时间函数的相关应用。1. 输入日期数据按组合键,可以...