基于Java的一个扫描路径下全部文件的程序

import java.io.File;
import java.io.FilenameFilter;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.regex.Pattern;

public class Directory {
    //处理多层文件筛选最好的数据结构是树,所以这里内部实现了一个简单的树
	static class FileTree{
		private String Parent;
		private List<FileTree> Childs = new ArrayList<>();
		
		public void setParent(String parent) {
			Parent = parent;
		}
		
		public List<FileTree> getChilds() {
			return Childs;
		}

		public String getParent() {
			return Parent;
		}

		public void add(FileTree fileTree) {
			this.Childs.add(fileTree);
		}
		
        //这里打印的方法做的不是很好,将就使用吧
		public static void PrintFileTree(FileTree fileTree,int time) {
			for(int i=0;i<time;i++) {
				System.out.print("-");
			}
			time++;
			System.out.println(fileTree.getParent());
			if(fileTree.getChilds().size()==0) {
				return ;
			}else {
				Iterator<FileTree> iterator = fileTree.getChilds().iterator();
				while(iterator.hasNext()) {
					PrintFileTree(iterator.next(),time);
				}
			}
		}
	}
	
    //实现文件名过滤器,用以使用正则表达式
	static class DirNameFilter implements FilenameFilter{
		private Pattern pattern;
		
		public DirNameFilter(String str) {
			pattern = Pattern.compile(str);
		}

		@Override
		public boolean accept(File dir, String name) {
			return pattern.matcher(name).matches();
		}
		
	}
	
    //第一个参数代表查询的文件路径,第二个参数代表正则表达式
	private static FileTree FileFound(String path,String regex) {
		FileTree fileTree = new FileTree();
		File file = new File(path);
		fileTree.setParent(file.getName());
		if(file.isDirectory()) {
			for(File f:file.listFiles(new DirNameFilter(regex))) {
				if(f.isDirectory()) {
					fileTree.getChilds().add(FileFound(f.getAbsolutePath(),regex));
				}else {
					FileTree fTree = new FileTree();
					fTree.setParent(f.getName());
					fileTree.getChilds().add(fTree);
				}
			}
		}
		return fileTree;
	}
	
	public static void main(String[] args) {
		FileTree.PrintFileTree(FileFound("E:\\maven\\apache-maven-3.5.4","!.*"),0);
	}
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值