获取一个OA文件夹目录下所有文件的扩展名及所对应扩展名文件的个数。注意: abc.txt的扩展名是txt, abc.java.txt的扩展名也是txt。

解题思路:

1.先判断文件第一层,如果是文件可以直接读取名字,如果是文件需要遍历,记录次数

2.可以利用map集合,因为一个键(key)只能对应一个数值,后面的可以将前面的覆盖

3.如果文件有很多层,需要用到递归思想,调用本身方法

4.最后通过遍历map循环读取个数。

代码如下:

import java.io.File;
import java.util.HashMap;
import java.util.Map;
/*获取一个OA目录下所有文件的扩展名及所对应扩展名文件的个数。
注意: abc.txt的扩展名是txt, abc.java.txt的扩展名也是txt。*/
public class Lx4 {
	
	static Map<String,Integer> m=new HashMap<String,Integer>();
public static void main(String[] args) {
	File fi=new File("D:/OA");
	getCount(fi);
	//遍历map循环
	for(Map.Entry<String, Integer> map:m.entrySet()) {
		String str1=map.getKey();
		int count=map.getValue();
		System.out.println(str1+"拓展名出现了"+count+"次");
	}
}
//先获取个数
public static void getCount(File f) {
	//判断是文件就直接获取名字
	if(f.isFile()) {
		String name=f.getName();
		//获取最后一个.的位置
		int index=name.lastIndexOf(".");
		String endName=name.substring(index);
		//判断map集合当中是否存在
		if(m.containsKey(endName)) {
			m.put(endName, m.get(endName)+1);
		}else {
			m.put(endName, 1);
		}
		//如果是文件夹,遍历
	}else {
		File[] arrf=f.listFiles();
		if(arrf.length>0) {
		for(File f1:arrf) {
			//递归
			getCount(f1);
		}
		}
	}
}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值