推荐一款超厉害的国产Java工具类Hutool


Hutool 是什么

官网:https://hutool.cn/

  • Hutool是一个小而全的Java工具类库,通过静态方法封装,降低相关API的学习成本,提高工作效率,使Java拥有函数式语言般的优雅,让Java语言也可以“甜甜的”;

  • Hutool中的工具方法来自每个用户的精雕细琢,它涵盖了Java开发底层代码中的方方面面,它既是大型项目开发中解决小问题的利器,也是小型项目中的效率担当;

  • Hutool是项目中“util”包友好的替代,它节省了开发人员对项目中公用类和公用工具方法的封装时间,使开发专注于业务,同时可以最大限度的避免封装不完善带来的bug。

入门和安装

Maven

在项目的pom.xml的dependencies中加入以下内容:

<dependency>
    <groupId>cn.hutool</groupId>
    <artifactId>hutool-all</artifactId>
    <version>5.5.8</version>
</dependency>

Gradle

compile 'cn.hutool:hutool-all:5.5.8'

非Maven项目

点击以下任一链接,下载hutool-all-X.X.X.jar即可:

注意 Hutool 5.x支持JDK8+,对Android平台没有测试,不能保证所有工具类或工具方法可用。 如果你的项目使用JDK7,请使用Hutool 4.x版本

编译安装

访问Hutool的Gitee主页:https://gitee.com/loolly/hutool 下载整个项目源码(v5-master或v5-dev分支都可)然后进入Hutool项目目录执行:

./hutool.sh installCopy to clipboardErrorCopied

然后就可以使用Maven引入了。

包含组件

一个Java基础工具类,对文件、流、加密解密、转码、正则、线程、XML等JDK方法进行封装,组成各种Util工具类,同时提供以下组件:

模块介绍
hutool-aopJDK动态代理封装,提供非IOC下的切面支持
hutool-bloomFilter布隆过滤,提供一些Hash算法的布隆过滤
hutool-cache简单缓存实现
hutool-core核心,包括Bean操作、日期、各种Util等
hutool-cron定时任务模块,提供类Crontab表达式的定时任务
hutool-crypto加密解密模块,提供对称、非对称和摘要算法封装
hutool-dbJDBC封装后的数据操作,基于ActiveRecord思想
hutool-dfa基于DFA模型的多关键字查找
hutool-extra扩展模块,对第三方封装(模板引擎、邮件、Servlet、二维码、Emoji、FTP、分词等)
hutool-http基于HttpUrlConnection的Http客户端封装
hutool-log自动识别日志实现的日志门面
hutool-script脚本执行封装,例如Javascript
hutool-setting功能更强大的Setting配置文件和Properties封装
hutool-system系统参数调用封装(JVM信息等)
hutool-jsonJSON实现
hutool-captcha图片验证码实现
hutool-poi针对POI中Excel和Word的封装
hutool-socket基于Java的NIO和AIO的Socket封装

可以根据需求对每个模块单独引入,也可以通过引入hutool-all方式引入所有模块。

日期时间工具-DateUtil

转换

Date、long、Calendar之间的相互转换

//当前时间
Date date = DateUtil.date();
//当前时间
Date date2 = DateUtil.date(Calendar.getInstance());
//当前时间
Date date3 = DateUtil.date(System.currentTimeMillis());
//当前时间字符串,格式:yyyy-MM-dd HH:mm:ss
String now = DateUtil.now();
//当前日期字符串,格式:yyyy-MM-dd
String today= DateUtil.today();

字符串转日期

DateUtil.parse方法会自动识别一些常用格式,包括:

  • yyyy-MM-dd HH:mm:ss

  • yyyy/MM/dd HH:mm:ss

  • yyyy.MM.dd HH:mm:ss

  • yyyy年MM月dd日 HH时mm分ss秒

  • yyyy-MM-dd

  • yyyy/MM/dd

  • yyyy.MM.dd

  • HH:mm:ss

  • HH时mm分ss秒

  • yyyy-MM-dd HH:mm

  • yyyy-MM-dd HH:mm:ss.SSS

  • yyyyMMddHHmmss

  • yyyyMMddHHmmssSSS

  • yyyyMMdd

  • EEE, dd MMM yyyy HH:mm:ss z

  • EEE MMM dd HH:mm:ss zzz yyyy

  • yyyy-MM-dd’T’HH:mm:ss’Z’

  • yyyy-MM-dd’T’HH:mm:ss.SSS’Z’

  • yyyy-MM-dd’T’HH:mm:ssZ

  • yyyy-MM-dd’T’HH:mm:ss.SSSZ

String dateStr = "2017-03-01";
Date date = DateUtil.parse(dateStr);

我们也可以使用自定义日期格式转化:

String dateStr = "2017-03-01";
Date date = DateUtil.parse(dateStr, "yyyy-MM-dd");

格式化日期输出

String dateStr = "2017-03-01";
Date date = DateUtil.parse(dateStr);

//结果 2017/03/01
String format = DateUtil.format(date, "yyyy/MM/dd");

//常用格式的格式化,结果:2017-03-01
String formatDate = DateUtil.formatDate(date);

//结果:2017-03-01 00:00:00
String formatDateTime = DateUtil.formatDateTime(date);

//结果:00:00:00
String formatTime = DateUtil.formatTime(date);

获取Date对象的某个部分

Date date = DateUtil.date();
//获得年的部分
DateUtil.year(date);
//获得月份,从0开始计数
DateUtil.month(date);
//获得月份枚举
DateUtil.monthEnum(date);
//.....

开始和结束时间

有的时候我们需要获得每天的开始时间、结束时间,每月的开始和结束时间等等,DateUtil也提供了相关方法:

String dateStr = "2017-03-01 22:33:23";
Date date = DateUtil.parse(dateStr);

//一天的开始,结果:2017-03-01 00:00:00
Date beginOfDay = DateUtil.beginOfDay(date);

//一天的结束,结果:2017-03-01 23:59:59
Date endOfDay = DateUtil.endOfDay(date);

日期时间偏移

日期或时间的偏移指针对某个日期增加或减少分、小时、天等等,达到日期变更的目的。Hutool也针对其做了大量封装

String dateStr = "2017-03-01 22:33:23";
Date date = DateUtil.parse(dateStr);

//结果:2017-03-03 22:33:23
Date newDate = DateUtil.offset(date, DateField.DAY_OF_MONTH, 2);

//常用偏移,结果:2017-03-04 22:33:23
DateTime newDate2 = DateUtil.offsetDay(date, 3);

//常用偏移,结果:2017-03-01 19:33:23
DateTime newDate3 = DateUtil.offsetHour(date, -3);Copy to clipboardErrorCopied

针对当前时间,提供了简化的偏移方法(例如昨天、上周、上个月等):

//昨天
DateUtil.yesterday()
//明天
DateUtil.tomorrow()
//上周
DateUtil.lastWeek()
//下周
DateUtil.nextWeek()
//上个月
DateUtil.lastMonth()
//下个月
DateUtil.nextMonth()Copy to clipboardErrorCopied

日期时间差

有时候我们需要计算两个日期之间的时间差(相差天数、相差小时数等等),Hutool将此类方法封装为between方法:

String dateStr1 = "2017-03-01 22:33:23";
Date date1 = DateUtil.parse(dateStr1);

String dateStr2 = "2017-04-01 23:33:23";
Date date2 = DateUtil.parse(dateStr2);

//相差一个月,31天
long betweenDay = DateUtil.between(date1, date2, DateUnit.DAY);Copy to clipboardErrorCopied

格式化时间差

有时候我们希望看到易读的时间差,比如XX天XX小时XX分XX秒,此时使用DateUtil.formatBetween方法:

//Level.MINUTE表示精确到分
String formatBetween = DateUtil.formatBetween(between, Level.MINUTE);
//输出:31天1小时
Console.log(formatBetween);Copy to clipboardErrorCopied

星座和属相

// "摩羯座"
String zodiac = DateUtil.getZodiac(Month.JANUARY.getValue(), 19);

// "狗"
String chineseZodiac = DateUtil.getChineseZodiac(1994);Copy to clipboardErrorCopied

其它

//年龄
DateUtil.ageOfNow("1990-01-30");

//是否闰年
DateUtil.isLeapYear(2017);Copy to clipboardErrorCopied

最后

以上都是从官网拷贝过来的,官网已经将所有的api都讲的很详细了,可以去学习一下。

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Hutool是一个Java工具类库,其中包含了许多实用的工具类,其中就包括导出Excel的工具类Hutool的Excel工具类可以方便地将Java对象导出为Excel文件,支持多种Excel格式,同时也支持自定义Excel样式。使用Hutool的Excel工具类,可以大大简化Java开发者的Excel导出工作。 ### 回答2: Hutool是一个Java工具类库,其中包括多个实用工具类,包括导出Excel功能。Hutool导出Excel工具类使用方便,提供丰富的API,可以满足大部分的导出需求。 Hutool导出Excel工具类支持多种导出方式,如导出到本地文件、导出到输出流、导出到HTTP响应等,方便不同场景下的使用。同时,Hutool导出Excel工具类支持导出自定义样式的Excel文档,可以按照自己的需求设置样式。 使用Hutool导出Excel工具类只需要引入相关的依赖即可,具体使用步骤如下: 1.添加依赖 在Maven项目中,需要在pom.xml文件中添加如下依赖: ``` <dependency> <groupId>cn.hutool</groupId> <artifactId>hutool-all</artifactId> <version>x.x.x</version> </dependency> ``` 其中x.x.x为Hutool的版本号,根据自己的需求选择。 2.构建Excel数据 使用Hutool导出Excel工具类需要先构建Excel文档中的数据,可以通过读取数据库或其他方式获取数据,并将数据封装为List或其他集合形式。 3.导出Excel文档 Hutool导出Excel工具类的API非常丰富,可以根据自己的需求选择不同的导出方式和样式。下面是一个基本的导出Excel文档的例子: ``` //构建Excel数据 List<User> userList = userService.getAllUsers(); //设置导出Excel文件名 String fileName = "用户列表.xlsx"; //设置导出Excel表格的表头 String[] headers = {"ID", "用户名", "邮箱"}; //设置导出Excel表格的数据 List<String[]> data = new ArrayList<>(); for (User user : userList) { String[] row = {String.valueOf(user.getId()), user.getUsername(), user.getEmail()}; data.add(row); } //导出Excel文档到本地文件 ExcelUtil.exportExcel(fileName, headers, data); ``` 以上代码中,首先通过userService.getAllUsers()方法获取用户列表数据,然后设置导出Excel文件名、表头和数据,最后调用ExcelUtil.exportExcel()方法导出Excel文档到本地文件。 总之,Hutool导出Excel工具类提供了方便、灵活的API,可以快速地完成Excel的导出功能。该工具类的使用非常简单,只需要几行代码即可完成整个导出过程。在处理Excel导出的场景下,Hutool是一个非常值得推荐Java工具类库。 ### 回答3: Hutool一款Java工具类库,其中包含了丰富的工具类以及函数库,实现了诸多常用的功能。Hutool的特点是轻量级、使用简单、性能高效、功能强大,是很多Java开发者常用的工具。 其中,Hutool的Excel模块中封装了导出Excel的功能,实现了轻松生成Excel文件的功能。使用Hutool导出Excel的步骤非常简单,首先我们需要创建ExcelWriter对象,调用write方法,写入数据,然后调用flush方法,将数据写入到Excel文件中,最后关闭ExcelWriter对象,释放资源。 在创建ExcelWriter对象时,我们需要指定输出流以及Excel文件格式。对于输出流,我们可以使用OutputStream,也可以直接指定输出文件路径。对于Excel格式,Hutool支持多种格式,如xls、xlsx、ods等。 在调用write方法时,我们可以使用不同的参数类型,如List、Map、Collection等来传递数据源,或者手动指定列名称、列类型、列宽、样式等信息。此外,Hutool还提供了一些方便的方法,如自适应列宽、数据类型转换等,使得数据导出更加灵活便捷。 总之,Hutool一款十分实用的Java工具类库,其Excel模块的导出功能便捷、易用、高效,为Java开发者提供了很多便利。对于需要进行数据导出的项目,使用Hutool可以更加快速、高效地实现数据导出,并提高开发效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值