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 操作代码。