Java中File的常用操作及方法

本文详细介绍Java中File类的使用方法,包括如何获取文件路径、检测文件状态、进行文件及目录的操作,并通过示例代码展示了如何列出指定目录下包括子文件夹在内的所有文件,以及如何使用文件过滤器过滤特定类型的文件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.获取File路径和检测状态:

1)操作File路径和名称:

File getAbsoluteFile() :获取绝对路径

String getAbsolutePath():获取绝对路径

String getPath() :获取文件路径

String getName() :获取文件名称

File getParentFile():获取上级目录文件

String getParent() :获取上级目录路径

 

2)检测File状态的方法:

boolean canExecute() :判断是否是可执行文件

boolean canRead() :判断该文件是否可读

boolean canWrite():判断该文件是否可写

boolean isHidden():判断该文件是否是隐藏文件

long lastModified():判断该文件的最后修改时间

long length():获取该文件的长度大小(单位字节)

---------------------------------------------------------------------

 

2.File类中方法-

1)文件操作:

boolean isFile() :是否是文件

boolean createNewFile() :创建新的文件

static File createTempFile(String prefix, String suffix) :创建临时文件

boolean delete() :删除文件

void deleteOnExit() :JVM停止时删除文件

boolean exists():判断文件是否存在

boolean renameTo(File dest) :重新修改名称

 

2)目录操作

boolean isDirectory() :判断是否是目录

boolean mkdir()  :创建当前目录

boolean mkdirs() :创建当前目录和上级目录

String[] list() :列出所有的文件名

File[] listFiles() :列出所有文件对象

static File[] listRoots() :列出系统盘符


需求:

列出指定目录中所有的文件,包括子文件夹中的所有文件

关键方法:File[] listFiles() 

public class ListFilesDemo {

	//需求:列出指定目录中所有的文件,包括子文件夹中的所有文件(使用递归算法(recursion)).
	public static void main(String[] args) {
		File dir = new File("E:/Program Files");
		listAllFile(dir);
	}

	private static void listAllFile(File f) {
		//第一级子文件
		File[] fs = f.listFiles();
		for (File file : fs) {
			//打印目录和文件
			System.out.println(file);
			//如果子文件是目录,则继续递归
			if(file.isDirectory()){
				listAllFile(file);
			}
		}
		
	}
}

需求:过滤掉不是.avi结尾的文件

关键类:文件过滤器(FilenameFilter)

public class FilenameFilterDemo {
	public static void main(String[] args) {
		File dir = new File("E:/Program Files/视频");
		File[] fs = dir.listFiles(new FilenameFilter() {
			
			@Override
			public boolean accept(File dir, String name) {
				//过滤条件:是文件(可过滤掉以.avi结尾的文件夹)、文件以.avi结尾(即满足条件则不过滤)
				return new File(dir,name).isFile() && name.endsWith(".avi");
			}
		});
		
		for (File file : fs) {
			System.out.println(file);
		}
	}
	
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值