Hutool File 教程

Hutool 是一个 Java 工具库,文件操作是其核心功能之一。以下是常用文件操作方法的介绍。

1. 引入依赖

XML 复制代码
<dependency>
    <groupId>cn.hutool</groupId>
    <artifactId>hutool-all</artifactId>
    <version>5.8.26</version>
</dependency>

2. 文件读写

写入文件

java 复制代码
// 将字符串写入文件(自动创建父目录)
FileUtil.writeString("Hello World", "test.txt", CharsetUtil.UTF_8);

// 追加内容
FileUtil.appendString("追加内容", "test.txt", CharsetUtil.UTF_8);

// 写入集合(每行一个元素)
List<String> lines = Arrays.asList("行1", "行2", "行3");
FileUtil.writeLines(lines, "test.txt", CharsetUtil.UTF_8);

读取文件

java 复制代码
// 读取为字符串
String content = FileUtil.readString("test.txt", CharsetUtil.UTF_8);

// 按行读取为 List
List<String> lines = FileUtil.readLines("test.txt", CharsetUtil.UTF_8);

// 读取为 byte 数组
byte[] bytes = FileUtil.readBytes("test.txt");

// 读取为 BufferedInputStream
BufferedInputStream in = FileUtil.getInputStream("test.txt");

3. 文件复制/移动/删除

java 复制代码
// 复制文件
FileUtil.copy("src.txt", "dest.txt", true);  // true 表示覆盖

// 移动文件
FileUtil.move(FileUtil.file("src.txt"), FileUtil.file("dest.txt"), true);

// 删除文件
FileUtil.del("test.txt");

// 清空文件夹(保留目录)
FileUtil.clean("directory");

4. 文件/目录判断

java 复制代码
// 判断文件是否存在
boolean exists = FileUtil.exist("test.txt");

// 判断是否为目录
boolean isDir = FileUtil.isDirectory("dir");

// 判断是否为文件
boolean isFile = FileUtil.isFile("test.txt");

// 是否为空(文件长度为0 或 目录无子文件)
boolean isEmpty = FileUtil.isEmpty("test.txt");

5. 创建目录/文件

java 复制代码
// 创建目录(自动创建父目录)
FileUtil.mkdir("parent/child/grandchild");

// 创建文件(自动创建父目录)
FileUtil.touch("path/newfile.txt");

6. 文件名/路径操作

java 复制代码
String path = "D:/data/photo.jpg";

// 获取文件名
String name = FileUtil.getName(path);  // photo.jpg

// 获取主文件名
String mainName = FileUtil.mainName(path);  // photo

// 获取扩展名
String ext = FileUtil.extName(path);  // jpg

// 获取父路径
String parent = FileUtil.getParent(path, 1);  // D:/data

7. 遍历文件

java 复制代码
// 遍历目录下所有文件(递归)
FileLoopFiles files = FileUtil.loopFiles("dir");

// 带过滤器的遍历
FileFilter filter = pathname -> pathname.getName().endsWith(".txt");
List<File> txtFiles = FileUtil.loopFiles("dir", filter);

8. 文件类型判断

java 复制代码
// 获取 MIME 类型
String mime = FileMimeUtil.getMimeType("photo.jpg");  // image/jpeg

// 判断是否为图片
boolean isImage = FileTypeUtil.getType(new File("photo.jpg")).startsWith("image");

9. 常用工具类速查

工具类 用途
FileUtil 文件读写、复制、删除、创建等
FileTypeUtil 文件类型判断
FileWriter 文件写入器(带缓存)
FileReader 文件读取器(带缓存)
FileNameUtil 文件名处理(扩展名、主名等)
FileCopier 更灵活的文件复制
WatchMonitor 文件/目录监听

10. 高级操作示例

使用 FileWriter/FileReader

java 复制代码
// 链式写入
FileWriter writer = new FileWriter("test.txt");
writer.write("第一行")
      .write("第二行")
      .close();

// 带编码的读取器
FileReader reader = new FileReader("test.txt", CharsetUtil.UTF_8);
String content = reader.readString();

文件监听

java 复制代码
WatchMonitor watchMonitor = WatchMonitor.create(
    new File("test.txt"),
    WatchMonitor.EVENTS_ALL  // 所有事件
);
watchMonitor.setWatcher(new Watcher() {
    @Override
    public void onCreate(WatchEvent<?> event, Path currentPath) {
        System.out.println("创建:" + event.context());
    }
    @Override
    public void onModify(WatchEvent<?> event, Path currentPath) {
        System.out.println("修改:" + event.context());
    }
    @Override
    public void onDelete(WatchEvent<?> event, Path currentPath) {
        System.out.println("删除:" + event.context());
    }
    @Override
    public void onOverflow(WatchEvent<?> event, Path currentPath) {
        System.out.println("溢出:" + event.context());
    }
});
watchMonitor.start();

Hutool 的文件操作 API 设计简洁且功能强大,大大简化了 Java 原生的 I/O 操作代码。

相关推荐
想你依然心痛10 分钟前
AtomCode在Python数据科学项目中的使用体验:从数据分析到可视化
开发语言·python·数据分析
许彰午16 分钟前
75_Python自动化办公之Word与PDF
python·自动化·word
河铃旅鹿25 分钟前
在Ubuntu系统上为Android交叉编译OpenSSL
android·linux·ubuntu
冰暮流星26 分钟前
flask之app.py讲解
后端·python·flask
大气的小蜜蜂28 分钟前
基于Python+PyQt5+SQLite的药房管理系统实现:事务一致性与界面解耦全流程解析
python·qt·sqlite
FriendshipT29 分钟前
Ultralytics:解读C2模块
人工智能·pytorch·python·深度学习·目标检测
长孙豪翔35 分钟前
引发事件的问题
java·linux·数据库
小张成长计划..39 分钟前
【Linux】7:第一个系统程序-进度条
linux·运维·服务器
MOONICK1 小时前
windows原生条件变量支持
c++·windows
枳实-叶1 小时前
【Linux驱动开发】第23天:spi_driver 的 probe / remove 函数实现规范
linux·驱动开发·c#