统计一个目录下各种文件类型及个数

https://www.cnblogs.com/liuyunche/p/14313589.html

统计一个目录下各种文件类型及个数

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
package cn.lyc;
 
import java.io.File;
import java.util.HashMap;
import java.util.Map;
 
public class Ex {
    //建立一个Map 用来存放文件类型和个数
    static Map<String, Integer> map = new HashMap<>();
    public static void main(String[] args) {
        //文件地址
        String name = "C:\\Users\\86176\\Desktop\\J";
        //调用方法
        count(new File(name));
        //遍历一遍map的key
        for (String key : map.keySet())
        System.out.printf("%s文件一共有%d个\n",key,map.get(key));
    }
    //递归方法
    public static void count(File file){
        if (file.isDirectory()){
            //public File[] listFiles()   返回一个抽象路径名数组,这些路径名表示此抽象路径名所表示目录中的文件。
            //File[] 数组中存储的是目录中的文件
            File[] files = file.listFiles();
            /**
             * for(元素类型File 元素变量fs : 遍历对象files){
             *      引用了fs的java语句;
             * }
             */
            for (File fs : files){
                if (fs.isDirectory()) count(fs);
                if (fs.isFile()){
                String name = fs.getName();<br>                if (name.contains(".")) {
                String ext = name.substring(name.lastIndexOf("."));
                //如果map中的key含有ext,就把map的value值加1,否则就给map添加一个key值
                    /**比如map为{.java = 1},ext的值为.java 那么map 的值就为{.java = 2}
                     * 如果map为{.java = 1},ext的值为.txt 那么map中就会多一个键值对 变为{.java = 1,.txt = 1}
                     */
                if (map.containsKey(ext)){
 
                    /**  map.get(key) 根据key来获取value
                     *   map.get(ext) ext 就是.java  意思就是获取.java的value
                     *   这里.Java的value表示同类型的个数,每发现一个进行加1
                     */
 
                    map.put(ext,map.get(ext)+1);
                    //System.out.println(map.get(ext));
                }else{
                    map.put(ext,1);
                }<br>            }
            }
            }
        }
    }
}

  

 

posted @   尐鱼儿  阅读(4)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示