JAVA输出指定目录下的子目录和子文件
2024-10-19 11:52:40
题目:给定一个目录,要求输出这个目录下面的子目录和子文件
逻辑:
- 先判断给定的是不是一个合法的目录,如果不是,则提示给定错误
- 如果是目录,那么使用File.listFile()获得这个目录下文件名的数组
- 循环遍历输出这个数组元素
- 输出名称之后,接着判断这个元素是文件还是目录
- 如果是目录,继续调用本方法来输出子目录
代码如下:
/**
* 输出指定目录下的所有子目录和子文件
*
* @author DXY
*
*/
public class HelloFile {
public static void main(String[] args) {
printFile(new File("D:\\test")); } public static void printFile(File file) {
if (file.isFile()) {
System.out.println("您给定的是一个文件"); // 判断给定目录是否是一个合法的目录,如果不是,输出提示
} else {
File[] fileLists = file.listFiles(); // 如果是目录,获取该目录下的内容集合 for (int i = 0; i < fileLists.length; i++) { // 循环遍历这个集合内容
System.out.println(fileLists[i].getName()); //输出元素名称
if (fileLists[i].isDirectory()) { //判断元素是不是一个目录
printFile(fileLists[i]); //如果是目录,继续调用本方法来输出其子目录
}
}
}
}
}
执行成功,结果正确,但是样子太丑陋了,如图
我们还需要加上缩进改造一下
public class HelloFile {
public static void main(String[] args) {
printFile(new File("D:\\test"),1);
} public static void printFile(File file,int tab) {
if (file.isFile()) {
System.out.println("您给定的是一个文件"); // 判断给定目录是否是一个合法的目录,如果不是,输出提示
} else {
File[] fileLists = file.listFiles(); // 如果是目录,获取该目录下的内容集合 for (int i = 0; i < fileLists.length; i++) { // 循环遍历这个集合内容
for (int j = 0; j < tab; j++) { //输出缩进
System.out.print("|---");
} System.out.println(fileLists[i].getName()); //输出元素名称 if (fileLists[i].isDirectory()) { //判断元素是不是一个目录
printFile(fileLists[i],tab+1); //如果是目录,继续调用本方法来输出其子目录,因为是其子目录,所以缩进次数 + 1
}
}
}
}
}
结果为:
最新文章
- linux 学习7 用户管理相关文件 r
- WebApi系列~开放的CORS,跨域资源访问对所有人开放
- easyui 上传文件代码
- Speex回声消除代码分析
- NLog 传递参数
- java rest版简单的webservice
- Delphi WebService 需要注意 转
- [Design Pattern] Front Controller Pattern 简单案例
- javascript 中 ";!function(){}() "; 是什么意思?
- 【filezilla】 ubuntu下安装filezilla
- 有字库API方法使用一二
- 让NotePad++添加到右键快捷方式
- 日期选择器和日期条控件 DateChooserAndDateFieldControls
- 1.print()与input()
- [py][mx]django模板继承-课程列表页
- Android属性动画:插值器与估值器
- Codeforces Round #112 (Div. 2) D. Beard Graph
- mysql的时间函数整理
- 剑指offer--36.整数中1出现的次数(从1到n整数中1出现的次数)
- 剑指offer:从头到尾打印链表
热门文章
- 美团外卖iOS多端复用的推动、支撑与思考
- 【基础知识】.Net基础加强 第二天
- Top 5 SSH Clients for Windows (Alternatives of PuTTY)
- redis 多实例 连接 加密码
- 证明自己吧--------Writeup
- Alpha 冲刺报告6
- Codeforces Round #260 (Div. 2) B. Fedya and Maths
- 【原】MySQL实用SQL积累
- hdu3790最短路径问题(BFS+优先队列)
- Accessing an element&#39;s parent with ElementTree(转)