Java中使用Hutool工具包读取文件,文件(csv,excel)乱码

Java中使用Hutool工具包读取文件

在Java开发中,处理文件是常见的任务之一,尤其是读取和写入CSV文件。CSV(Comma-Separated Values)文件是一种简单的、用逗号分隔的文本文件格式,它广泛用于数据交换和存储。Hutool是一个Java工具包,它提供了很多便捷的工具方法,其中就包括对CSV文件的读取和写入功能。

1. Hutool简介

Hutool是一个Java工具包,它封装了Java中常用的一些操作,如日期、文件、加密、JSON等。Hutool的目的是简化Java开发,让Java开发更简单、更高效。

2. 引入Hutool依赖

在使用Hutool之前,需要在项目的pom.xml文件中添加Hutool的依赖。

<dependency>
    <groupId>cn.hutool</groupId>
    <artifactId>hutool-all</artifactId>
    <version>5.7.16</version> <!-- 请使用最新版本 -->
</dependency>

3. 读取CSV文件

Hutool提供了CsvUtil类来处理CSV文件。以下是使用Hutool读取CSV文件的基本步骤:

 CsvReader reader = CsvUtil.getReader();  // 进行创建csv读取器

 // 设置文件读取的分隔符
reader.setFieldSeparator(','); // 默认为 , 可不进行设置

// 通过hutool的文件工具进行读取csv文件,并且指定文件的编码
CsvData data = reader.read(FileUtil.file("you.csv"), Charset.forName("GBK"));

List<CsvRow> rows = data.getRows(); // 获取到csv文件的每一行的数据存放到list

//若有标题,则获取首行标题
List<String> firstRawList = rows.get(0).getRawList();

//遍历行
for (CsvRow csvRow : rows) {
    List<String> rawList = csvRow.getRawList(); // csv一行的数据存放到list中
    System.out.println(rawList);
    // 结果: [id,name,age1] [John Doe,30] ......
}

注意:你的csv文件的编码格式一定要进行指定,csv文件非常的注重编码格式,因为一般的csv文件的多少GBK,如果你的编码是UTF-8,请切换到对应的编码。

4. 解析Excel文件:ExcelUtil

//读取Excel文件的内容-选定工作表名读取
ExcelReader  reader = ExcelUtil.getReader(file,fileSheetName);
//根据指定行开始读取所有的内容
List<List<Object>> rows = reader.read(1, reader.getRowCount());
//在获取到所有的数据后,要关闭reader(切记),操作文件总是失败,最后才发现在service调用没有关闭流,粗心大意了!
reader.close();

5.解析JSON文件:JSONUtil

//根据特定的字符集编码读取JSON文件
JSONObject jsonObject = JSONUtil.readJSONObject(file, Charset.forName(encode));

注意事项

  • 确保读取文件的路径和编码正确。
  • CSV文件的格式应该正确,字段之间用逗号分隔,字段内部不应包含逗号。
  • 在处理数据时,注意类型转换和异常处理。

通过上述步骤,你可以方便地使用Hutool工具包在Java中读取常用的文件。Hutool提供了很多其他实用的功能,可以根据需要进一步探索.

  • 7
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值