linux去掉java路径_Java显示目录文件列表和删除目录
Java显示目录文件列表和删除目录
以d:\a目录为例,假设D:\a目录内的结构如下:
d:\a
|--a.sql
|--back.log
|--b
| |--e
| | |--1.txt
| | |--2.txt
| | `--3.txt
| `--f
| |--4.txt
| |--5.txt
| `--6.txt
|--c
| |--e
| | |--ace1.txt
| | |--ace2.txt
| | `--ace3.txt
| `--f
| |--4.txt
| |--5.txt
| `--6.txt
`--d
|--a.java
|--abc (1).txt
|--abc (2).txt
|--abc (3).txt
|--b.java
`--c.java
4.1 示例1:列出整个目录中的文件(递归)
思路:
1.遍历目录d:\a。
2.每遍历到d:\a中的一个目录就遍历这个子目录。因此需要判断每个遍历到的元素是否是目录。
以下是从普通代码到递归代码前的部分代码:
File dir = new File("d:/a");
File[] file_list = dir.listFiles();
for (File list : file_list) {
if (list.isDirectory()) {
File dir_1 = list.listFiles(); //此处开始代码重复,且逻辑上可能会无限递归下去
if (dir_1.isDirectory()) {
....
}
} else {
System.out.println(list.getAbsolutePath());
}
}
对重复的代码部分进行封装,于是使用递归方法,既封装代码,又解决无限递归问题。最终代码如下:
import java.io.*;
public class ListAllFiles {
public static void main(String[] args){
File dir = new File("d:/a");
System.out.println("dir------>"+dir.getAbsolutePath());
listAll(dir);
}
public static void listAll(File dir){
File[] file_list = dir.listFiles();
for (File file : file_list) {
if (file.isDirectory()) {
System.out.println("dir------>"+file.getAbsolutePath());
listAll(file);
} else {
System.out.println("file------>"+file.getAbsolutePath());
}
}
}
}
4.2 示例2:列出整个目录中的文件(队列)
思路:
1.遍历给定目录。将遍历到的目录名放进集合中。
2.对集合中的每个目录元素进行遍历,并将遍历到的子目录添加到集合中,最后每遍历结束一个目录就从集合中删除它。
3.这样一来,只要发现目录,就会一直遍历下去,直到某个目录整个都遍历完,开始遍历下一个同级目录。
需要考虑的是使用什么样的集合。首先集合内目录元素无需排序、不同目录内子目录名可能重复,因此使用List集合而非set集合,又因为频繁增删元素,因此使用linkedlist而非arraylist集合,linkedlist集合最突出的特性就是FIFO队列。
相比于递归遍历,使用队列遍历目录的好处是元素放在容器中,它们都在堆内存中,不容易内存溢出。
import java.util.*;
import java.io.*;
public class ListAllFiles2{
public static void main(String[] args){
File dir = new File("d:/a");
Queue file_queue = new Queue(); //构建一个队列
File[] list = dir.listFiles();
for (File file : list) { //遍历顶级目录
if(file.isDirectory()) {
System.out.println("dir------>"+file.getAbsolutePath());
file_queue.add(file);
} else {
System.out.println("file------>"+file.getAbsolutePath());
}
}
while (!file_queue.isNull()) { //从二级子目录开始,逐层遍历
File subdirs = file_queue.get(); //先取得二级子目录名称
File[] subFiles = subdirs.listFiles();
for (File subdir : subFiles) { //遍历每个下一级子目录
if(subdir.isDirectory()) {
System.out.println("dir------>"+subdir.getAbsolutePath());
file_queue.add(subdir); //如果内层还有子目录,添加到队列中
} else {
System.out.println("file------>"+subdir.getAbsolutePath());
}
}
}
}
}
class Queue{
private LinkedList linkedlist;
Queue() {
linkedlist = new LinkedList();
}
public void add(E e){
linkedlist.addFirst(e); //先进
}
public E get(){
return linkedlist.removeLast(); //先出
}
public boolean isNull(){
return linkedlist.isEmpty();
}
}
4.3 示例3:树形结构显示整个目录中的文件(递归)
思路:
1.先列出一级目录和文件。
2.如果是目录,则加一个构成树形的前缀符号。然后再遍历这个目录,在此需要递归遍历。
import java.io.*;
public class TreeFiles {
public static void main(String[] args){
File dir = new File("d:/a");
System.out.println(dir.getName());
listChilds(dir,1);
}
public static void listChilds(File f,int level){
String prefix = "";
for(int i=0;i
prefix = "| " + prefix;
}
File[] files = f.listFiles();
for (File file : files) {
if(file.isDirectory()) {
System.out.println(prefix + file.getName());
listChilds(file,level+1);
} else {
System.out.println(prefix + file.getName());
}
}
}
}
结果如下:
a
| a.sql
| b
| | e
| | | 1.txt
| | | 2.txt
| | | 3.txt
| | f
| | | 4.txt
| | | 5.txt
| | | 6.txt
| back.log
| c
| | e
| | | ace1.txt
| | | ace2.txt
| | | ace3.txt
| | f
| | | 4.txt
| | | 5.txt
| | | 6.txt
| d
| | a.java
| | abc (1).txt
| | abc (2).txt
| | abc (3).txt
| | b.java
| | c.java
4.4 删除整个目录
import java.io.*;
public class FileDelete{
public static void main(String[] args){
File file = new File("d:/a");
rm(file);
}
public static void rm(File f){
if(!f.exists()){
System.out.println("file not found!");
return;
} else if(f.isFile()){
f.delete();
return;
}
File[] dir = f.listFiles();
for(File file : dir) {
rm(file);
}
f.delete();
}
}
linux去掉java路径_Java显示目录文件列表和删除目录相关推荐
- java显示目录文件列表和删除目录
以d:\a目录为例,假设D:\a目录内的结构如下: d:\a |--a.sql |--back.log |--b | |--e | | |--1.txt | | |--2.txt | | `--3.t ...
- linux一,系统分区 Linux的盘符结构 Linux常用命令: 一,目录/文件的处理命令
文章目录 一,系统分区 Linux的盘符结构 Linux常用命令: 一,目录/文件的处理命令 一,系统分区 概念:在硬盘上产生文件系统的过程 第一步:磁盘分区(创建隔断) 分区规则:主分区最多只能分4 ...
- 部署阿里云盘的目录文件列表程序教程
现在拥有阿里云盘账号的伙伴应该很多了,大部分都有1T的存储容量,小部分有6T,重要的是上传下载的速度很快,相对于其他的网盘,要么是传输速度慢,要么是存储容量太低,所以阿里云盘算是目前最好的免费网盘了, ...
- ls 显示目录内容列表
ls 显示目录内容列表 补充说明 ls命令 用来显示目标列表,在Linux中是使用率较高的命令.ls命令的输出信息可以进行彩色加亮显示,以分区不同类型的文件. 语法 ls(选项)(参数) 选项 -a: ...
- Android-用ListView显示SDCard文件列表
本文简单实现了用ListView显示SDCard文件列表,目录的回退等功能暂不讨论 获取文件列表,files即为所选择目录下的所有文件列表 filePath = Environment.getExte ...
- 使用window的cmd命令输出目录文件列表清单
使用window的cmd命令输出目录文件列表清单 使用window的cmd命令,输出文件夹文件列表. 注意,先进行cmd模式 dir >print.txt dir /b >print.tx ...
- 阿里云盘的目录文件列表程序Alist
网盘列表软件很多,老苏之前分享过 Z-file 和 ShareList,这两款软件都支持多家第三方存储,可以直接将网盘从个人使用变成一个面向大众的资源网站,不过老苏觉得还是自己低调用用就好了,毕竟是会 ...
- 织梦后台管理模板无法正常显示模板文件列表解决方法
织梦后台管理模板无法正常显示模板文件列表解决方法 参考文章: (1)织梦后台管理模板无法正常显示模板文件列表解决方法 (2)https://www.cnblogs.com/dedehtml/p/991 ...
- linux tree命令 树结构显示目录文件
命令简介 tree命令的中文意思为"树",功能是以树形结构列出指定目录下的所有内容,包括所有文件.子目录及子目录里的目录和文件. 命令格式 tree [option] [direc ...
最新文章
- Statistical language model 统计语言模型
- SPOJ1812 LCS2
- it计算机哪些专业术语,IT之家学院:笔记本电脑专业术语科普
- ubuntu 14.04 修改PS1提示符
- java 6 基础_java基础(6)
- 笔记本触摸板没反应,且设置里没有触摸板选项
- GD32F103学习笔记(2)——在GD32F103移植STM32F103代码
- 怎么把一个gif表情包分解成多个?
- 教务辅助管理系统mysql_教务管理系统(项目)
- ElasticSearch创建索引映射文档+IK分词器
- 色彩对比广告设计_为什么我们都需要使用色彩对比检查器
- 【大数据】Hadoop生态系统及其组件
- android 2.1你好八月,八月你好优美句子
- 十年AI学者影响力盘点:何恺明排名第一,成为全球最具影响力学者
- 用于说明卷积神经网络(ConvNet)的Python脚本
- 5.14.1.14 LBA Status Information
- TCP和 UDP的区别
- verilog学习:一个简单的入门verilog例子
- Altium Designer中导出bxl文件
- 出门问问发布企业级场景的智能交互屏TicKasa Show,适用于多种场景