一、File类
1、File类要点概述
- File类直接父类为Object类;
- 一个File类对象,表示一个磁盘上的目录或者文件;
- File类提供了与平台无关的方法(使用抽象路径等概念。Java自动进行不同系统平台的文件路径描述与抽象文件路径之间的转换)来操作磁盘上的目录或者文件,比如新增,修改,删除;
- File类直接处理文件或者文件系统;
- File类没有指定信息怎样从文件读取或者向文件存储;
- File类描述了文件本身的属性
- File类可以用来获取或处理与磁盘文件的信息,比如权限、时间、日期和存储路径;
- File类还可以浏览子目录层次结构;
2、File对象的生成
生成File对象(注意:只是生成File对象,并没有创建目录或者文件)的三种构造方法如下:
//生成一个e盘下的text.txt 的File文件对象
File file = new File("e:/text.txt");
//生成一个e盘下的io的File目录对象
File file = new File("e:/io");
//生成一个file目录下的File文件对象
File file2 = new File(file, "abc.txt");
3、目录管理和文件管理
(1)目录管理
目录操作的主要方法为:
- public bollean mkdir():根据抽象路径来创建目录,抽象路径的之前的每一级目录必须存在;
- public bollean mkdirs():根据抽象路径来创建目录,抽象路径的之前的每一级目录可以不存在;
import java.io.File;
public class FileTest3
{
public static void main(String[] args)
{
File file1 = new File("e:/io/xyz");
/**
* File.mkdir()在指定位置创建一个新的目录,但是当指定的根目录不存在
* (即路径中间有不存在的文件夹时),或者要创建的目录已经存在,创建不成功
*/
System.out.println(file1.mkdir());
File file2 = new File("e:/io/abc/xyz");
/**
* File.mkdirs()在指定位置创建一个新的目录,如果路径中间的文件夹也不存在,则会以此创建所有目录
* ,如果要创建的目录已经存在,创建不成功
*/
System.out.println(file2.mkdirs());
}
}
- public String[] list() 返回抽象路径名表示的路径中的目录和文件名,不包含子目录中的文件和目录
- public File[] listFiles() 返回抽象路径名表示的路径中的目录和文件名,不包含子目录中的文件和目录
import java.io.File;
public class FileTest4
{
public static void main(String[] args)
{
File file = new File("E:\\io");
/**
* File.list()返回指定路径下的目录及文件的名字数组,
* 不包括子目录下的目录和文件。
*/
// String[] fileNames = file.list();
// for(String name : fileNames)
// System.out.println(name);
/**
* File.listFiles()返回指定路径下的目录及文件的数组,
* 不包括子目录下的目录和文件。
*/
File[] files = file.listFiles();
for(File f : files)
System.out.println(f.getName());
}
}
4、File类中常用的方法
String getName() //返回文件名
String getPath() //返回相对路径
String getAbsolutePath() //返回绝对路径
String getParent() //返回父目录名
boolean renameTo( File newName) //重命名由此抽象路径名表示的文件,前提该文件必须存在。
long length() //返回文件的长度
boolean delete() //删除文件
boolean mkdir() //创建目录
String[] list() //返回抽象路径名表示的路径中的目录和文件名,不包含子目录中的文件和目录
boolean exists() //判断文件是否存在
boolean canWrite() //判断给文件是否可写
boolean canRead() //判断给文件是否可读
boolean isFile() //判断是否为文件
boolean isDirectory() //判断是否为目录
5、FilenameFilter简介
FilenameFilter可以用于File.list()方法,可以限制list方法返回的文件数目,使它仅返回那些与一定文件名或者过滤相匹配的文件。未达到这种目的,必须使用list()的第二种形式(方法重载)。
// FFObj是一个实现了FilenameFilter接口类的对象
String[] list(FilenameFilter FFObj)
- FilenameFilter仅定义了一个方法,accept()。该方法被列表中得每个文件调用一次。它的通常形式如下:
/**
*当directory指定的目录中的文件(即那些与filename参数相匹配的文件)包含在列表时,
*accept()方法返回true,否则返回false。
*/
boolean accept(File directory, String filename)
- demo
import java.io.File;
import java.io.FilenameFilter;
public class FileTest7
{
public static void main(String[] args)
{
File file = new File("e:/io/xyz");
/**
* FilenameFilter用来对文件的名字进行过滤
* 此处用匿名内部类来实现
*/
String[] names = file.list(new FilenameFilter()
{
/**
* dir 目录里的一个个文件
* name 文件对应的文件名
* 此处只需对文件名进行操作即可
* 返回true时,File.list()则返回找到的对应的文件名称数组。
* 返回false时,File.list()则返回空
*/
@Override
public boolean accept(File dir, String name)
{
if (name.endsWith(".java"))
{
return true;
}
return false;
}
});
for(String name : names)
System.out.println(name);
}
}
6、listFiles方法简介
以下三种方式的listFiles方法返回的都是File数组,而不是文件的名称。
//返回所有的文件
File[ ] listFiles()
//返回满足指定FilenameFilter接口的文件
File[ ] listFiles(FilenameFilterFFObj)
//返回满足指定FileFilter的路径名的文件.FileFilter只定义了一个accept()方法,
//该方法被列表中的每个文件调用一次
File[ ] listFiles(FileFilterFObj)
//如果文件被包括在列表中(即与path参数匹配的文件),
//accept()方法返回true,如果不被包括,则返回false。
boolean accept(File path)