导航:首页 > 文件处理 > 循环遍历文件夹java

循环遍历文件夹java

发布时间:2023-11-23 23:22:17

A. java怎么遍历一个盘下的所有文件

用递归算法,递归可以理解成自己调用自己,但要有终止条件

首先是判断这个是文件还是文件夹。文件的话就处理文件;文件夹的话,列出里面的文件,再对每一个文件做同样的判断处理

下面是删除一个文件夹(改成列出所有文件的话,你把删除操作改成放入集合操作),所有删除都是只能删除一个文件或者是空文件夹,所以遇到文件夹就得把里面的文件全部删除

	privatestaticvoiddeleteFile(Filefile){
if(!file.exists())
return;
System.out.print("删除===");
if(file.isFile()){
System.out.println("文件:"+file);
file.delete();
}else{
System.out.println("文件夹:"+file);
for(Filef:file.listFiles()){
deleteFile(f);
}
file.delete();
}
}

同理(Node是自己定义的类,主要包含了name(String),children (List<Node>)这两个属性来表达层级):

遍历了这个文件夹之后返回这个文件夹的Node作为上一个文件加的children之一,这就把文件夹的层级结构列出来了,当然你也可以用Map来存储这些数据

/**
*列出文件目录结构
*
*@paramfolder
*@paramfnf
*@return
*/
privatestaticNodelsFiles(Filefolder){
Noden=newNode();
n.setName(folder.getName());
n.setPath(folder.getAbsolutePath());
if(folder.isFile()){
n.setLeaf(true);
n.setSize(folder.length());
}else{
n.setLeaf(false);
File[]folders=folder.listFiles();//列出文件夹底下的文件
for(Filefile:folders){//遍历每个文件做相同操作
Nodecn=lsFiles(file);
n.getChildren().add(cn);
n.setSize(n.getSize()+cn.getSize());
}
}

returnn;
}

下面是不分层次结构来列出所有文件(纯手写,可能有语法错误)

/**
*列出文件路径
*
*@paramfolder
*@paramfnf
*@return
*/
privatestaticList<String>lsFiles(Filefolder){
List<String>l=newArrayList<String>();
l.add(folder.getAbsolutePath());
if(folder.isFile()){
//处理file
}else{
File[]folders=folder.listFiles();
for(Filefile:folders){
l.addAll(lsFiles(file));
}
}
returnl;
}

效果

B. java怎么实现遍历文件夹并压缩的功能

不考虑一个文件夹下有另外一个文件夹的情况下,代码如下

publicstaticvoidZipFolder(Filedirectory)throwsException{
FileOutputStreamfout=newFileOutputStream("输出压缩文件test.zip的位置");
ZipOutputStreamzout=newZipOutputStream(fout);
for(Filefile:directory.listFiles()){
byte[]buffer=Files.readAllBytes(file.toPath());

ZipEntryzipEntry=newZipEntry(file.getName());
zout.putNextEntry(zipEntry);
zout.write(buffer);
zout.closeEntry();
}
zout.flush();
zout.close();
}

C. java 怎么遍历 文件夹下的 文件

import java.io.File;
import java.util.ArrayList;
import java.util.List;

public class Traverse {
/** List游标 */
private static Integer sign = 0;
/** 初始路径 */
private static String initPath = "E:\\";
/** 文件夹路径 */
public static List<String> filePath = new ArrayList<String>();

public static void main(String[] args) {

/** 开始遍历节点 */
System.out.println("---star---");
filePath.add(initPath);// 将首目录放入遍历队列
while (sign < filePath.size()) {
getFilePath();
sign++;
}
System.out.println("---end---");
}

/**
* <p>
* 获取所有节点路径
*
* @return void
*/
public static void getFilePath() {
try {
File file = new File(filePath.get(sign));
File[] files = file.listFiles();
for (int i = 0; i < files.length; i++) {
boolean isFile = false;
isFile = files[i].isFile();
if (!isFile) {
filePath.add(files[i].getAbsolutePath());
System.out.println(files[i].getAbsolutePath());
}
}
} catch (Exception e) {

}
}
}
这个是遍历给定目录下的所有子目录,并存放在list中,如果你要遍历文件就从list中逐个取目录再遍历判断是不是文件就行了!

D. java遍历文件夹

主要应用递归算法

/**
*
*/
package com.dianziermu.io;

import java.io.File;
import java.util.ArrayList;
import java.util.List;

/**
* 遍历文件夹及其下面的所有文件夹,递归
*
* @author 点子二木
* @date 2009-6-10
* @version 1.0
*/
@SuppressWarnings("unchecked")
public class FolderIO {

static List<File> gblFoldList = new ArrayList();

/**
* @param args
*/
public static void main(String[] args) {
String path = "c:\\Program Files";// 将要搜索目录路径
System.out.println("获取"+path + "目录下所有文件夹,正在加载......");
readFolder(path);

printFolder();
}

/**
* 获取文件对象
*
* @param path
*/
private static void readFolder(String path) {

File dir = new File(path);// 建立代表Sub目录的File对象,并得到它的一个引用
if (dir.exists()) {// 检查目录是否存在
File[] dirList = dir.listFiles();// 获取该目录下所有文件和文件夹

for (int index = 0; index < dirList.length; index++) {
if (dirList[index].isDirectory()) {// 如果是文件夹
// System.out.println(dirList[index]);
gblFoldList.add(dirList[index]);
readFolder(dirList[index].getPath());// 注意:此处递归
}
}
} else {
System.out.println("该文件夹不存在");
}
}

/**
* 打印文件夹对象
*/
private static void printFolder() {
for (int index = 0; index < gblFoldList.size(); index++) {
System.out.println(gblFoldList.get(index));
}

}

}

E. java中遍历文件夹

import java.io.File;
public class Test {
public static void main(String[] args) throws Exception {
//递归显示C盘下所有文件夹及其中文件
File root = new File("c:");
showAllFiles(root);
}

final static void showAllFiles(File dir) throws Exception{
File[] fs = dir.listFiles();
for(int i=0; i<fs.length; i++){
System.out.println(fs[i].getAbsolutePath());
if(fs[i].isDirectory()){
try{
showAllFiles(fs[i]);
}catch(Exception e){}
}
}
}
}
打字不易,如满意,望采纳。

阅读全文

与循环遍历文件夹java相关的资料

热点内容
压缩怎么eq闪 浏览:740
流密码算法openssl 浏览:262
怎么数黄豆个数python 浏览:799
混沌序列加密的结论 浏览:224
最新脱单app哪个好 浏览:638
如何用自己电脑做服务器做网页 浏览:140
服务器安全配置要考什么证书 浏览:633
ipadpro可以编程 浏览:541
外国的程序员和中国的程序员 浏览:151
抖音小店app如何联系客服 浏览:975
linux打开多个终端 浏览:500
linux中的命令 浏览:580
优化小米6相机算法 浏览:259
ak47pdf 浏览:150
人与文化pdf 浏览:640
原子币app在哪里注册的 浏览:530
php数组保存文件 浏览:226
无理的命令 浏览:510
问道手游解压失败是什么原因 浏览:776
mysql命令提示 浏览:374