File类介绍
-
java.io.File 类是文件和目录路径名的抽象表示形式,主要用于文件和目录的创建、查找和删除等操作。
-
路径是唯一的,同一台计算机中不可能存在有两个不同的文件但路径又相同
-
File的三种构造方法:
public class FileDemo1 {
public static void main(String[] args) throws IOException {
// 1 File(String pathname) 通过将给定的路径名字符串转换为抽象路径名来创建新的File实例
File f1 = new File("F:\\a.txt");
System.out.println(f1); // F:\a.txt
// 2 File(String parent, String child) 父路径名字符串 和 子路径名字符串
File f2 = new File("F:\\abc", "a.txt");
System.out.println(f2); // F:\abc\a.txt
// 3 File(File parent, String child) 父抽象路径名 和 子路径字符串
File f3 = new File(new File("F:\\abc\\a"), "a.txt");
System.out.println(f3); // F:\abc\a\a.txt
/*错误示范:File类构造函数的本质就是将两个字符串连接起来,不会检验路径是否正确*/
File f4 = new File(new File("F:\\abc\\x.jpg"), "aa.txt");
System.out.println(f4); // F:\abc\x.jpg\aa.txt
}
}
相对路径和绝对路径
- 绝对路径:从盘符开始
File file1 = new File(“D:\\itheima\\a.txt”);
- 相对路径:相对于当前项目下的路径
File file2 = new File(“a.txt”);
File file3 = new File(“模块名\\a.txt”);
File类的常用功能
- 创建
public boolean createNewFile() // 创建一个新的空的文件
public boolean mkdir() // 创建一个单级文件夹
public boolean mkdirs() // 创建一个多级文件夹
public class FileDemo3 {
public static void main(String[] args) throws IOException {
File f1 = new File("day10\\a.txt"); // 模块名\\文件名
System.out.println(f1.createNewFile()); // 创建文件 true
File f2 = new File("day10\\abc");
System.out.println(f2.mkdir()); // 创建单级文件夹 true
File f3 = new File("day10\\aaa\\bbb\\ccc");
// 使用mkdir()函数创建多级文件夹
System.out.println(f3.mkdir()); // false
File f4 = new File("day10\\aaa\\bbb\\ccc");
System.out.println(f4.mkdirs()); // 创建多级文件夹 true
/*已经存在的文件再次创建的话会失败*/
}
}
- 总结 : mkdirs()函数好用,其可以创建多级文件夹,但是却不能创建文件,例如它会将a.txt创建为一个文件夹而不是文件
- 删除
public boolean delete() // 删除由此抽象路径名表示的文件或目录
- 注意事项:
- delete方法直接删除不走回收站
- 如果删除的是一个文件,直接删除
- 如果删除的是一个文件夹,需要先删除文件夹中的内容,最后才能删除文件夹
- File类判断和获取功能
public boolean isDirectory() // 测试此抽象路径名表示的File是否为目录
public boolean isFile() // 测试此抽象路径名表示的File是否为文件
public boolean exists() // 测试此抽象路径名表示的File是否存在
public String getAbsolutePath() // 返回此抽象路径名的绝对路径名字符串
public String getPath() // 将此抽象路径名转换为路径名字符串,与创建文件所用的路径名相同
public String getName() // 返回由此抽象路径名表示的文件或目录的名称
- File类高级获取功能
public File[] listFiles() // 返回此抽象路径名表示的目录中的文件和目录的File对象数组
-
注意事项:
- 当调用者不存在时,返回null
- 当调用者是一个文件时,返回null
- 当调用者是一个空文件夹时,返回一个长度为0的数组
- 当调用者是一个有内容的文件夹时,将里面所有文件和文件夹的路径放在File数组中返回
- 当调用者是一个有隐藏文件的文件夹时,将里面所有文件和文件夹的路径放在File数组中返回,包含隐藏内容
-
统计一个文件夹内的文件类型(不包含嵌套)
public class Test2 {
public static void main(String[] args) {
HashMap<String, Integer> hm = new HashMap<>();
File f = new File("day10\\统计文件个数文件夹");
File[] files = f.listFiles();
for (File file : files) {
if (file.isDirectory()) {
// 如果是目录
add("文件夹", hm);
} else {
// 如果是文件
String fileName = file.getName();
String[] splits = fileName.split("\\.");
String trueName = splits[splits.length - 1];
add(trueName, hm);
}
}
// 遍历结果
Set<Map.Entry<String, Integer>> entries = hm.entrySet();
for (Map.Entry<String, Integer> entry : entries) {
String key = entry.getKey();
Integer value = entry.getValue();
System.out.println(key + ":" + value + "个");
}
}
public static void add(String name, HashMap<String, Integer> hm) {
if (hm.containsKey(name)) {
hm.put(name, hm.get(name) + 1);
} else {
hm.put(name, 1);
}
}
}