Java——键盘录入一个文件夹路径,统计该文件夹(包含子文件夹)中每种类型的文件及个数,注意:用文件类型(后缀名,不包含.(点),如:"java","txt")作为key,

键盘录入一个文件夹路径,统计该文件夹(包含子文件夹)中每种类型的文件及个数,注意:用文件类型(后缀名,不包含.(点),如:“java”,“txt”)作为key,
用个数作为value,放入到map集合中,并用两种方式遍历map集合
例如:
doc 的类型的文件有 3 个
java 的类型的文件有 5 个
txt 的类型的文件有 7 个
实现代码:

import java.io.File;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Scanner;
public class HomeWork2 {
	public static void main(String[] args) {
		System.out.print("请输入文件夹路径:");
//		测试路径:D:\360MoveData\Users\xucc\Desktop\aaa
		File file = new File(new Scanner(System.in).next());
		HashFile(file);
	}

	public static void HashFile(File file) {
		File[] fileArr = file.listFiles();
		List<String> list = new ArrayList<String>();//新建一个数组,用来存储所有文件的后缀名
		for (File f : fileArr) {
			if (!f.isDirectory()) {
				int index = f.toString().indexOf(".");//获取文件名中“.”的下标
				String fileName = f.toString().substring(index + 1);// 截取文件后缀名
				list.add(fileName);
			} else {
				File[] file2 = f.listFiles();
				for (File f2 : file2) {
					int index = f2.toString().indexOf(".");
					String fileName = f2.toString().substring(index + 1);// 截取文件后缀名
					list.add(fileName);
				}
			}
		}
		
		HashMap<String, Integer> hm = new HashMap<>();
		int value = 1;
		for (String f : list) {
			if (!hm.containsKey(f))
				hm.put(f, 1);
			else
				hm.put(f, ++value);
		}
		
		for(String key : hm.keySet()) 
			System.out.println(key +"的类型的文件有"+hm.get(key)); 
		System.out.println("________________");
		 
		for (Map.Entry<String, Integer> me : hm.entrySet()) {
			String key = me.getKey();
			int numValue = me.getValue();
			System.out.println(key + "的类型的文件有" + numValue);
		}

	}
}

输出结果:在这里插入图片描述

好的,这是一个比较基础的文件处理问题,下面是 Java 代码实现: ```java import java.io.File; import java.util.HashMap; import java.util.Map; import java.util.Scanner; public class CountFilesDemo { public static void main(String[] args) { Scanner sc = new Scanner(System.in); System.out.print("请输入文件夹路径:"); String path = sc.nextLine(); File folder = new File(path); if (!folder.exists()) { System.out.println("输入路径不存在!"); return; } int fileCount = 0; int folderCount = 0; Map<String, Integer> typeCount = new HashMap<>(); countFiles(folder, typeCount); // 统计文件夹文件个数文件夹个数 System.out.println("文件夹个数:" + folderCount); System.out.println("文件个数:" + fileCount); System.out.println("每种类型文件个数:" + typeCount); } public static void countFiles(File folder, Map<String, Integer> typeCount) { int fileCount = 0; int folderCount = 0; File[] files = folder.listFiles(); if (files == null || files.length == 0) return; for (File file : files) { if (file.isDirectory()) { folderCount++; countFiles(file, typeCount); // 递归统计文件夹文件 } else { fileCount++; String type = getFileType(file.getName()); if (typeCount.containsKey(type)) { typeCount.put(type, typeCount.get(type) + 1); } else { typeCount.put(type, 1); } } } System.out.println(folder.getAbsolutePath() + " 文件个数:" + fileCount); System.out.println(folder.getAbsolutePath() + " 文件夹个数:" + folderCount); } public static String getFileType(String fileName) { int index = fileName.lastIndexOf("."); if (index == -1) { return "unknown"; } return fileName.substring(index); } } ``` 这个程序使用了 Java 的 `File` 类,可以递归遍历文件夹的所有文件夹文件。在遍历过程,我们可以统计文件夹个数文件个数,并且使用 `Map` 类型的变量 `typeCount` 统计每种类型文件个数。最后输出结果即可。 需要注意的是,这段代码只是一个简单的实现,没有考虑异常情况,比如输入的路径不存在,或者遍历过程某个文件文件夹无法访问等情况。在实际应用需要根据具体情况进行处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值