Java遍历一个文件夹下的全部文件
Java工具中为我们提供了一个用于管理文件系统的类,这个类就是File类,File类与其它流类不同的是,流类关心的是文件的内容。而File类关心的是磁盘上文件的存储。
一,File类有多个构造器,经常使用的构造器有:
1。public File(String pathname){}
在pathname路径下创建文件对象
2。public File(String path,String name){}
在path參数指定的文件夹中创建具有给定名字的File对象。假设path为null,构造器将使用当前文件夹创建对象
3,public File(File dir, String name){}
File对象dir表示一个文件夹,在dir參数指定的文件夹中创建具有给定名字的File对象,假设dir为null,
构造器将使用当前文件夹创建对象
二。获得文件的权限属性:
1,表明文件是否可读,可写。可运行
boolean canRead()
boolean canWrite()
boolean canExecute()
2。设置文件的可读。可写,可运行
boolean setReadable(bollean state,bollean ownerOnly)
boolean setWritable((bollean state,bollean ownerOnly)
boolean setExecutable((bollean state,bollean ownerOnly)
3,删除文件
boolean delete()
假设文件被删除则返回true,否则返回false
void deleteOnExit()
在虚拟机关闭时将文件删除
4。推断文件是否存在
boolean exists()
5,获得文件路径名
String getCanonicalPath()
返回包括这个文件的规范路径名的字符串该方法会使用恰当的文件夹分隔符,并能够获得底层文件系统所选择的大写和小写处理方式
String getName()
返回包括这个File对象的文件名称的字符串。但不包括路径信息
6。推断File为文件还是文件夹
boolean isDirectory()
推断是否为一个文件夹
boolean isFile()
推断是否为一个文件
7,获得File对象包括的文件名称和文件夹名
String[] list()
返回这个File对象包括的文件名称和文件夹名构成的字符创数组
String[] list(FilenameFilter filter)
返回有这个File对象包括的满足过滤器条件的文件名称和文件夹名构成的字符串数组
File还有很多方法属性,跟多的能够查看API文档
如今,使用File类来遍历一个文件夹下的全部文件。我的程序过程为:
1,获取pathName的File对象
2,推断该文件或文件夹是否存在。不存在时在控制台输出提醒
3。推断假设不是一个文件夹。就推断是不是一个文件,时文件则输出文件路径
4,获取此文件夹下的全部文件名称与文件夹名的字符串数组
5。假设是一个文件夹。搜索深度currentDepth+1,输出文件夹名后。进行递归
6,假设是文件,则直接输出文件名称
程序例如以下:
import java.io.File;
import java.io.IOException; public class DirErgodic { private static int depth=1; public static void find(String pathName,int depth) throws IOException{
int filecount=0;
//获取pathName的File对象
File dirFile = new File(pathName);
//推断该文件或文件夹是否存在。不存在时在控制台输出提醒
if (!dirFile.exists()) {
System.out.println("do not exit");
return ;
}
//推断假设不是一个文件夹,就推断是不是一个文件,时文件则输出文件路径
if (!dirFile.isDirectory()) {
if (dirFile.isFile()) {
System.out.println(dirFile.getCanonicalFile());
}
return ;
} for (int j = 0; j < depth; j++) {
System.out.print(" ");
}
System.out.print("|--");
System.out.println(dirFile.getName());
//获取此文件夹下的全部文件名称与文件夹名
String[] fileList = dirFile.list();
int currentDepth=depth+1;
for (int i = 0; i < fileList.length; i++) {
//遍历文件文件夹
String string = fileList[i];
//File("documentName","fileName")是File的还有一个构造器
File file = new File(dirFile.getPath(),string);
String name = file.getName();
//假设是一个文件夹。搜索深度depth++,输出文件夹名后。进行递归
if (file.isDirectory()) {
//递归
find(file.getCanonicalPath(),currentDepth);
}else{
//假设是文件,则直接输出文件名称
for (int j = 0; j < currentDepth; j++) {
System.out.print(" ");
}
System.out.print("|--");
System.out.println(name); }
}
} public static void main(String[] args) throws IOException{
find("D:\\MongoDB", depth);
}
}
測试截图:
Java遍历一个文件夹下的全部文件的更多相关文章
- Java遍历文件夹下的所以文件
利用Java递归遍历文件夹下的所以文件,然后对文件进行其他的操作.如:对文件进行重命名,对某一类文件进行重编码.可以对某一工程下的全部.java文件进行转码成utf-8等 代码如下,这里只对文件进行重 ...
- JAVA 遍历文件夹下的所有文件
JAVA 遍历文件夹下的所有文件(递归调用和非递归调用) 1.不使用递归的方法调用. public void traverseFolder1(String path) { int fileNum = ...
- JAVA 遍历文件夹下的所有文件(递归调用和非递归调用)
JAVA 遍历文件夹下的所有文件(递归调用和非递归调用) 1.不使用递归的方法调用. public void traverseFolder1(String path) { int fileNum = ...
- 用Java实现将多级文件夹下的所有文件统一放到一个文件夹中
每次下了电影(男生懂得呦),每部电影都放在一个单独的文件夹里,看的时候很是不方便啊,一直重复着进入文件夹.后退,再进.再退的操作,而手动把这些电影全部复制出来又太繁琐.因此为了解决这个问题,用IO写了 ...
- php 遍历一个文件夹下的所有文件和子文件
php 遍历一个文件夹下的所有文件和子文件 <?php /** * 将读取到的目录以数组的形式展现出来 * @return array * opendir() 函数打开一个目录句柄,可由 clo ...
- Java基础面试操作题: File IO 文件过滤器FileFilter 练习 把一个文件夹下的.java文件复制到另一个文件夹下的.txt文件
package com.swift; import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.File ...
- C/C++遍历Windows文件夹下的所有文件
因为文件夹中往往包含文件和文件夹.想要遍历所有的文件,必须遍历文件夹中所有的文件夹.很显然,这个描述满足递归的两个要素:(1)问题的规模在不断的缩小,且新问题的模式与旧问题相同.很显然文件夹中含有子文 ...
- java读取某个文件夹下的所有文件
import java.io.FileNotFoundException;import java.io.IOException;import java.io.File; public class Re ...
- java:多层文件夹情况下,判断文件夹下是否有文件夹,并获取到没有文件夹的名字的方法
业务问题案例 在公司遇到的一个问题,本以为很小很好解决,没想到花了一下午时间.图给的是文件路径,page1下有10个文件夹,每个有的有文件夹或者文件,要求得到page1下(即:123456789,10 ...
随机推荐
- Reuse a SSL socket
It's possible to reuse a SSL socket after proper cleanup. See SSL Socket free and shutdown on stacko ...
- socket相关函数
socket() 我们使用系统调用socket()来获得文件描述符:#include<sys/types.h>#include<sys/socket.h>int socket( ...
- oracle文件 结构01
1.减少数据的冗余(例如使用id) 2.保证数据库一致性 关联表越多越慢 主机名 hosts 文件 ntp 时间同步
- 汇编学习pushl, popl
- Spring Boot 与任务
一.任务 1.异步任务 package com.yunche.task.service; import org.springframework.stereotype.Service; /** * @C ...
- 判断机型是否为iphoneX
判断机型是否为iphoneX isIPhoneX() { var u = navigator.userAgent; var isIOS ...
- 最长上升子序列(动态规划递推,LIS)
1759:最长上升子序列 题目: 总时间限制: 2000ms 内存限制: 65536kB 描述 一个数的序列bi,当b1 < b2 < ... < bS的时候,我们称这个序列是上升的 ...
- 【IDEA】【Git】pull代码始终无法pull到最新的代码或者提示pull no items 【解决方式】
最近pull代码老是提示pull no items,但是本地并不是最新的代码,看了各种博客始终无法解决,最后靠自己的方式解决.下面是解决方法. 方法:1.首先git --> repository ...
- wake states
Wake states Table of Contents 1. Turbulent Wake 2. turbulent wake of a circular cylinder 3. Referenc ...
- 洛谷 2574 XOR的艺术
[题解] 线段树维护区间中1的个数就好了.每次修改就打上标记并把区间的sum改为len-sum. #include<cstdio> #include<algorithm> #i ...