File类也是Java中一个比较重要的类,通过他我们可以实现对文件的一系列操作,其内置了很多方法,下面我将按方法的功能分块,逐一讲解:

构造方法

常用方法

官方API如下(基于Java 11):

创建目录

构造方法以及mkdir()方法

   @Test
public void mkdirTest() {
//创建一个抽象路径,用于之后操作,可以是一级目录可以是多级目录
//此举并不会在内存中产生一个文件,想要产生文件必须调用方法(mkdir)
//File类的实例是不可变的; 也就是说,一旦创建, File对象表示的抽象路径File永远不会改变。 //几种方式如下: //默认在当前项目根目录
//File file1 = new File("xxx");
//File file11 = new File("a/b/c/d/e"); //在当前项目所在盘符下
//File file2 = new File("/xxx"); //在指定位置
//File file3 = new File("c:/xxx");
//File file4 = new File("c:\\xxxx"); //2.创建方法 mkdir()和 mkdirs() 返回一个Boolean值,
// 创建成功返回true,失败返回false,如果指定目录下已经存在则不会创建成功(false)
// 两者区别是:mkdir只能创建单级目录,mkdirs可以创建多级目录
// 如果声明的是多级目录,则调用mkdirs,声明的是单级则调用mkdir //System.out.println(file1.mkdir());
//System.out.println(file11.mkdir()); //false 因为声明的是多级的,应该调用mkdirs
//System.out.println(file11.mkdirs());
//System.out.println(file2.mkdir());
//System.out.println(file3.mkdir());
//System.out.println(file4.mkdir());
}

createNewFile()createTempFile()

    @Test
public void createTest() {
//创建目录
File file = new File("d:/hello/abc");
if (!file.exists()) {
file.mkdirs();
System.out.println("创建成功!");
}
//在刚创建的目录中在创建一个文件createNewFile()
File file1 = new File("d:/hello/abc/hello.txt");
try {
file1.createNewFile();
} catch (IOException e) {
System.out.println("创建失败!");
} if (file1.exists()) {
file1.delete();
System.out.println("删除成功!");
} //在刚创建的目录中在创建一个指定文件格式的文件(例如 (...).jpg) //createTempFile(String prefix, String suffix,【 File directory】)
//参数
//prefix - 用于生成文件名的前缀字符串; 必须至少三个字符长
//suffix - 用于生成文件名的后缀字符串; 可以是null ,在这种情况下将使用后缀".tmp"
//directory - 要在其中创建文件的目录,如果要使用默认临时文件目录, null (选填,不填默认为null)
//结果 表示新创建的空文件的抽象路径名
try {
File.createTempFile("123", ".jpg", file);
} catch (IOException e) {
e.printStackTrace();
}
}

判断 is...

    @Test
public void existsTest() {
//1.exists()测试此抽象路径名表示的文件或目录是否存在。 File file11 = new File("a/b/c/d/e");
System.out.println(file11.exists()); //false
file11.mkdirs();
System.out.println(file11.exists()); //true } @Test
public void isTest() {
File file11 = new File("a/b/c/d/e");
System.out.println(file11.exists()); //false
file11.mkdirs();
System.out.println(file11.exists()); //true //测试此抽象路径名表示的文件是否为普通文件。
System.out.println(file11.isFile()); //当前为目录,所以为false
System.out.println(file11.listFiles()[0].isFile()); //1.txt 所以为true //测试此抽象路径名表示的文件是否为目录。
System.out.println(file11.isDirectory()); //测试此抽象路径名是否为绝对路径。
System.out.println(file11.isAbsolute()); //测试此抽象路径名指定的文件是否为隐藏文件。
System.out.println(file11.isHidden());
}

toString()

用得不多。。。

    @Test
public void toStringTest() {
//4.toString() 将所指路径转换为字符串
//File file11 = new File("a/b/c/d/e");
//System.out.println(file11.toString()); //"a\b\c\d\e"
}

获取字节数length()

    @Test
public void lengthTest() {
File file = new File("E:\\HelloJava\\Java_Study_Beiyou\\src\\day_12_13\\zuoye\\AddFile.java");
if (file.exists()) {
//获取文件字节数,如果是文件夹则为 0
System.out.println(file.length());
}
}

删除文件

    @Test
public void deleteTest() {
//3.删除文件方法delete() //默认在当前项目根目录
//File file1 = new File("xxx");
//File file11 = new File("a/b/c/d/e"); //如果此文件或者目录不存在,则删除失败返回false
//如果此文件不是空文件(空目录),删除失败false
//如果此路径是多级目录,则只删除最内层的文件或者目录
//System.out.println(file1.delete()); //true
//System.out.println(file11.delete()); //true
}

如果要删除带有文件的目录,可以参考这篇点击跳转

更名操作

    @Test
public void renameTest() throws IOException {
File file = new File("ahello/a/abc.txt");
// System.out.println(file.mkdirs());
System.out.println(file.createNewFile());
// file.mkdirs();
System.out.println(file); //如果重命名的文件已存在,则不会重命名
System.out.println(file.renameTo(new File("a/b/c/abcd.txt")));
System.out.println(file.getName()); //注意事项:
//第一种场景:同一路径下文件重命名【文件重命名】
//第二种场景:将文件从一个路径移动另一个路径下,并且移动的文件进行重命名【文件移动重命名】
//第三种场景:修改文件夹的名称,文件夹里面没有文件的时候修改成功!
}

比较两个路径

    @Test
public void compareToTest() {
//如果参数等于此抽象路径名,则为零;如果此抽象路径名按字典顺序小于参数,则为小于零;如果此抽象路径名在字典上大于参数,则值大于零
File f1 = new File("d:\\hello");
File f2 = new File("d:\\hello\\a");
File f3 = new File("d:\\hell");
File f4 = new File("d:\\hello");
//System.out.println(f1.compareTo(f2)); //-2
//System.out.println(f1.compareTo(f3)); //1
//System.out.println(f1.compareTo(f4)); //0
}

获取和修改最后修改时间

    @Test
public void lastModifiedAndSetTest() {
//记录文件的最后修改时间,是一个long时间戳
File file = new File("E:\\HelloJava\\Java_Study_Beiyou\\src\\day_12_13");
long time = file.lastModified();
System.out.printf("%tF %<tT", time); //2021-12-14 08:44:38 System.out.println();
//boolean setLastModified(long time) 设置此抽象路径名指定的文件或目录的上次修改时间。
long now = System.currentTimeMillis();
file.setLastModified(now);
System.out.printf("%tF %<tT", now); //2021-12-14 18:15:32
}

获取子文件(也可以是目录)

    @Test
public void listTest() { /*
String[] list() 返回一个字符串数组,用于命名此抽象路径名表示的目录中的文件和目录。
String[] list(FilenameFilter filter) 返回一个字符串数组,用于命名由此抽象路径名表示的目录中的文件和目录,以满足指定的过滤器。
File[] listFiles() 返回一个抽象路径名数组,表示此抽象路径名表示的目录中的文件。
File[] listFiles(FileFilter filter) 返回一个抽象路径名数组,表示此抽象路径名表示的目录中满足指定过滤器的文件和目录。
File[] listFiles(FilenameFilter filter) 返回一个抽象路径名数组,表示此抽象路径名表示的目录中满足指定过滤器的文件和目录。
static File[] listRoots() 列出可用的文件系统根目录。
*/
File file = new File("E:\\谷歌"); // list() 返回的是字符串数组
String[] listStr = file.list();
System.out.println(Arrays.toString(listStr)); // listFiles() 返回的是 File[] 可以对文件直接操作
File[] listF = file.listFiles();
for (File file1 : listF) {
System.out.print(file1.getName() + ", ");
} // listRoots() 列出可用的文件系统根目录。
System.out.println();
File[] listRoots = File.listRoots();
for (File root : listRoots) {
System.out.println(root.getPath());
} //对文件筛选操作
//两种方式
// FilenameFilter filter --- boolean accept(File dir, String name); dir为文件根目录(不包含此文件) name为文件名
// FileFilter filter -------- boolean accept(File pathname); pathname为文件路径(包含此文件) //list(FilenameFilter filter) FilenameFilter支持lambda,两个参数()
String[] listStrs = file.list((path, name) -> name.endsWith("zip")); //列出所有以zip结尾的文件
System.out.println(Arrays.toString(listStrs)); //listFiles(FilenameFilter filter)
FilenameFilter filter;
File[] listFiles = file.listFiles((path, name) -> name.matches(".*[\\d+].*")); //获取所有文件名中带有数字的
for (File file1 : listFiles) {
System.out.print(file1.getName() + ", ");
} //listFiles(FileFilter filter)
File[] lfs = file.listFiles(e -> e.getName().matches(".*[\\u4e00-\\u9fa5]+.*")); //获得包含中文的文件
for (File f : lfs) {
System.out.print(f.getName() + ", ");
} }

get方法大汇总(基本都是获取)

    @Test
public void getTest() throws IOException {
/*
返回值类型 方法名 描述 File getAbsoluteFile() 返回此抽象路径名的绝对形式。
String getAbsolutePath() 返回此抽象路径名的绝对路径名字符串。
File getCanonicalFile() 返回此抽象路径名的规范形式。
String getCanonicalPath() 返回此抽象路径名的规范路径名字符串。
String getName() 返回此抽象路径名表示的文件或目录的名称。
String getPath() 将此抽象路径名转换为路径名字符串。
String getParent() 返回此抽象路径名父项的路径名字符串,如果此路径名未指定父目录,则返回 null 。
File getParentFile() 返回此抽象路径名父项的抽象路径名,如果此路径名未指定父目录,则返回 null 。
long getFreeSpace() 通过此抽象路径名返回分区 named中未分配的字节数。
long getUsableSpace() 通过此抽象路径名返回分区 named上此虚拟机可用的字节数。
long getTotalSpace() 通过此抽象路径名返回分区 named的大小。
*/ File file = new File("E:\\HelloJava\\Java_Study_Beiyou\\src\\day_12_13");
System.out.println(file.getAbsoluteFile()); //E:\HelloJava\Java_Study_Beiyou\src\day_12_13
System.out.println(file.getAbsolutePath()); //E:\HelloJava\Java_Study_Beiyou\src\day_12_13
System.out.println(file.getCanonicalFile()); //E:\HelloJava\Java_Study_Beiyou\src\day_12_13
System.out.println(file.getCanonicalPath()); //E:\HelloJava\Java_Study_Beiyou\src\day_12_13
System.out.println(file.getName()); //day_12_13
System.out.println(file.getPath()); //E:\HelloJava\Java_Study_Beiyou\src\day_12_13
System.out.println(file.getParent()); //E:\HelloJava\Java_Study_Beiyou\src
System.out.println(file.getParentFile()); //E:\HelloJava\Java_Study_Beiyou\src
System.out.println(file.getFreeSpace()); //339921727488
System.out.println(file.getTotalSpace()); //786633322496
System.out.println(file.getUsableSpace()); //339921727488
}

测试与设置权限

@Test
public void canTest() {
/*
boolean canExecute() 测试应用程序是否可以执行此抽象路径名表示的文件。
boolean canRead() 测试应用程序是否可以读取此抽象路径名表示的文件。
boolean canWrite() 测试应用程序是否可以修改此抽象路径名表示的文件。
*/
File file = new File("aaa\\bbb\\ccc\\test.txt");
System.out.println(file.canExecute()); //true
System.out.println(file.canRead()); //true
System.out.println(file.canWrite()); //true
} @Test
public void setTest() {
/*
boolean setExecutable(boolean executable) 一种方便的方法,用于设置此抽象路径名的所有者执行权限。
boolean setExecutable(boolean executable, boolean ownerOnly) 设置此抽象路径名的所有者或每个人的执行权限。
boolean setReadable(boolean readable) 一种方便的方法,用于设置此抽象路径名的所有者读取权限。
boolean setReadable(boolean readable, boolean ownerOnly) 设置此抽象路径名的所有者或每个人的读取权限。
boolean setReadOnly() 标记此抽象路径名指定的文件或目录,以便仅允许读取操作。
boolean setWritable(boolean writable) 一种方便的方法,用于设置此抽象路径名的所有者写入权限。
boolean setWritable(boolean writable, boolean ownerOnly) 设置此抽象路径名的所有者或每个人的写入权限。
*/
File file = new File("aaa\\bbb\\ccc\\test.txt"); //System.out.println(file.setExecutable(false, false)); //false
//System.out.println(file.canExecute()); //true
//System.out.println(file.canRead()); //true
//System.out.println(file.canWrite()); //true //System.out.println(file.setReadable(false,false));
//System.out.println(file.canExecute()); //true
//System.out.println(file.canRead()); //true
//System.out.println(file.canWrite()); //true //System.out.println(file.setWritable(false,false));
//System.out.println(file.canExecute()); //true
//System.out.println(file.canRead()); //true
//System.out.println(file.canWrite()); //false //System.out.println(file.setReadOnly());
//System.out.println(file.canExecute()); //true
//System.out.println(file.canRead()); //true
//System.out.println(file.canWrite()); //false
}

Java中File类的方法详解的更多相关文章

  1. Java中hashCode与equal方法详解

    转载自http://blog.csdn.net/jiangwei0910410003/article/details/22739953 Java中的equals方法和hashCode方法是Object ...

  2. Java中 hashCode()方法详解

    先来看下Object源码里hashcode方法: /**     * Returns a hash code value for the object. This method is      * s ...

  3. java 中toString()方法详解

    1.toString()方法 Object类具有一个toString()方法,你创建的每个类都会继承该方法.它返回对象的一个String表示,并且对于调试非常有帮助.然而对于默认的toString() ...

  4. java中枚举类的使用详解

    /* * 通过JDK5提供的枚举来做枚举类 */ public enum Direction2 { FRONT("前"), BEHIND("后"), LEFT( ...

  5. Java 中的异常和处理详解

    Java 中的异常和处理详解 原文出处: 代码钢琴家 简介 程序运行时,发生的不被期望的事件,它阻止了程序按照程序员的预期正常执行,这就是异常.异常发生时,是任程序自生自灭,立刻退出终止,还是输出错误 ...

  6. Java 中File类的createNewFile()与createTempFile(), delete和deleteOnExit区别

    1. Java 中File类的createNewFile()与createTempFile()的区别 最近,在看代码时看到了一个方法, File.createTempFile() ,由此联想到File ...

  7. java中File的delete()方法删除文件失败的原因

    java中File的delete()方法删除文件失败的原因 学习了:http://hujinfan.iteye.com/blog/1266387 的确是忘记关闭了: 引用原文膜拜一下: 一般来说 ja ...

  8. python中requests库使用方法详解

    目录 python中requests库使用方法详解 官方文档 什么是Requests 安装Requests库 基本的GET请求 带参数的GET请求 解析json 添加headers 基本POST请求 ...

  9. PHP 中 16 个魔术方法详解

    PHP 中 16 个魔术方法详解   前言 PHP中把以两个下划线__开头的方法称为魔术方法(Magic methods),这些方法在PHP中充当了举足轻重的作用. 魔术方法包括: __constru ...

随机推荐

  1. centos6.5-Apache优化

    Apache的网页压缩功能 一.配置网页压缩功能 在配置压缩功能以前访问网页的响应头部 Response Headers view source Accept-Ranges:bytes Connect ...

  2. 细谈 Java 匿名内部类 【分别 使用 接口 和 抽象类实现】

    1.前言 匿名内部类是什么东西? 没有名字的内部类就是匿名内部类. 什么场景使用? 匿名内部类适合创建那种只需要一次使用的类. 这是个很有用的东西,可想而知,如果不使用匿名内部类,哪些只需要使用一次的 ...

  3. Word文档学习小练习链接

    1. < Word2010初学> https://www.toutiao.com/i6487370439910752782/ 2. <Word2010格式化可爱的家乡> htt ...

  4. 移动端字体图标不显示的Bug

    用16进制编码的字体图标在部分小米机型显示不正常. 测试机型:小米1,小米1s,小米2浏览器:微信6.1内置浏览器,QQ浏览器 5.7 X5内核字体图标:不显示svg图标:显示正常 以下来自额微信内置 ...

  5. hyperf 如何对AMQP消息进行手动消费?

    转发自白狼栈:查看原文 在使用 hyperf 官方自带的 AMQP 队列时你会发现,不需要我们再额外启动进程对消息进行消费.这是因为默认情况下,使用 @Consumer 注解时,hyperf 会为我们 ...

  6. winform设置所有窗体统一图标

    class WindowHookerManager { static WindowHooker hooker = new WindowHooker(); public static void SetA ...

  7. spring事务隔离级别、传播机制以及简单配置

    转自 https://blog.csdn.net/zht741322694/article/details/78676964 一.spring支持的事务声明方式1.  编程式事务  当系统需要明确的, ...

  8. Qt之QFontDialog

    widget.h: #ifndef WIDGET_H #define WIDGET_H #include <QWidget> class Widget : public QWidget { ...

  9. 【简记】SpringBoot禁用Swagger

    楔子 Swagger 是 Java Web 开发中常用的接口文档生成类库,在开发和前后端联调时使用它来模拟接口调用能提高开发效率.但是,在生产环境可能并不需要它,一个原因是启用它会延长程序启动时间(动 ...

  10. 一步一步超级详细的zabbix安装教程

    安装说明: 1. 虚拟机上安装两台全新Linux: zabbix-server:192.168.255.128 zabbix-agent :192.168.255.129 2. zabbix-serv ...