Java文件操作——File
创建File
isFile()、length()、exists()、createNewFile()、
File.separator /
isDirtory()、 mkdir()、mkdirs()、 delete()、
listFiles()、FileFilter(){};
-------------------------------淫荡分隔----------------------------------
创建File文件对象
java.io.File用于表示文件(目录),也就是说程序员可以通过File类在程序中操作硬盘上的文件和目录。
File类只用于表示文件(目录)的信息(名称、大小等),换句话说只能访问文件或目录的相关属性,不能对文件的内容进行访问。
public class Filedemo1 { public static void main(String[] args) { // java.io.File 判断是否为文件 File file= new File("./1.txt"); boolean isFile = file.isFile(); if(isFile){ System.out.println("是一个文件"); }else{ System.out.println("不是一个文件"); } /* * 查看文件占用的字节量 注意目录无大小 * */ long length =file.length(); System.out.println("占用"+length+"字节"); /* * 查看File描述文件或目录是否为真实存在 */ boolean exists = file.exists(); if(exists){ System.out.println("存在"); }else{ System.out.println("不存在"); } }
class FileDemo2{ public static void main(String[] args) throws IOException { /* * 在当前项目根目录下创建文件test.txt * */ //使用一个File对象描述该文件 // File.separator 代替/ File file= new File("."+File.separator+"2.txt"); //判断该文件是否在硬盘中不存在 if(!file.exists()){ //创建该文件 file.createNewFile(); } System.out.println(file.exists()); } }
File表示目录信息
1. isDirectory()
File的isDirectory方法用于判断当前File对象表示的是否为一个目录
2. mkdir方法
File的mkdir方法用于创建此抽象路径名指定的目录。其方法定义:
boolean mkdir()
返回值:当且仅当已创建目录时,返回 true;否则返回 false
3. mkdirs方法
File的mkdirs方法用于创建此抽象路径名指定的目录,包括所有必需但不存在的父目录。注意,此操作失败时也可能已经成功地创建了一部分必需的父目录。其方法定义:
boolean mkdirs()
返回值:当且仅当已创建目录以及所有必需的父目录时,返回 true;否则返回 false
class FileDemo3{ public static void main(String[] args) { /* * 在当前目录下创建a/b/c目录 * */ File dir = new File("a"+File.separator+"b"+File.separator+"c"); if(!dir.exists()){ dir.mkdirs(); } System.out.println(dir.exists()); } }
4. delete方法
在删除目录时要特别注意:需要保证此为空目录才可以成功删除(目录中不能含有任何子项)。
5. listFiles方法
File的listFiles方法用于返回一个抽象路径名数组,这些路径名表示此抽象路径名表示的目录中的文件。其方法定义:
File[] listFiles()
返回值:抽象路径名数组,这些路径名表示此抽象路径名表示的目录中的文件和目录。如果目录为空,那么数组也将为空。如果抽象路径名不表示一个目录,或者发生 I/O 错误,则返回 null。
class FileDemo7{ public static void main(String[] args) { /* * 输出当前目录下的所有子项 */ File dir =new File("."); if(dir.isDirectory()){ //获取当前目录下的所有子项 File[] subs =dir.listFiles(); for(File sub : subs){ /* * File 提供一个方法用于获取文件或目录的名字 * String getName() */ if(sub.isFile()){ System.out.println("文件"+ sub.getName()); }else{ System.out.println("目录"+ sub.getName()); } } } } }
6. FileFilter接口
通过listFiles方法我们可以获取一个目录下的所有子项,但有些时候我们并不希望获取全部子项,而是想获取部分满足我们实际需求的子项时,我们可以使用File的重载方法:
File[] listFiles(FileFilter filter)
这里我们看到,该重载方法 要求我们传入一个参数,其类型是FileFilter。什么是FileFilter呢? FileFilter是用于抽象路径名的过滤器,说白了就是定义一个规律规则,那么结合listFiles方法,我们就可以将满足此过滤规则的子项返回,其他则忽略。
FileFilter是一个接口,所以当我们需要定义某种过滤规则时,我们可以定义一个类来实现这个接口,而此接口的实例可传递给 File 类的 listFiles(FileFilter) 方法。
例如:
File[] list = dir.listFiles(new FileFilter() { @Override public boolean accept(File pathname) { return pathname.getName().startsWith("."); } });
/** * 获取一个目录下满足条件的子项 * @author Administrator * */ class FileDemo9{ public static void main(String[] args) { /* * 获取当前目录下所有的文本文件 * 目标:获取名字是以txt结尾的 */ File dir = new File("."); FileFilter filter = new FileFilter() { /** * 文件过滤器 */ @Override public boolean accept(File file) { /* * 该方法是用来检查参数File是否符合要求的、 * 符合返回true */ System.out.println("过滤子项:"+file.getName()); return file.getName().endsWith(".txt"); } }; /* * 重载的listFile 方法 * File[] listFile(FileFilter filter) * 返回当前目录下满足给定过滤器条件的子项 */ File[] subs= dir.listFiles(filter); for(File sub: subs){ System.out.println(sub.getName()); } } }
该方法的参数FileFilter实例的accept方法并进行过滤,listFiles方法会将所有accept方法返回true的子项保留并返回。这个例子里我们会将dir中子项的名字以"."开头的返回。