【java基础:递归】搜索目录下的文件夹和子文件

要求:

文件夹的位置为:D盘,名称为myjava(可替换成电脑现有的文件夹);

需求为获取该文件夹内的文件目录,以及目录下的子文件;

import java.io.File;

public class test {
    public static void main(String[] args) {
       //搜索D:\myjava 所有目录和子文件
        File dir = new File("D:\\myjava");
        printDir(dir);
    }
    //构造一个printDir方法
    public static void printDir(File dir){
        //获取子文件和目录
        File[] files = dir.listFiles();
        for (File f:files){
            //判断是文档还是目录
            if (f.isFile()){
                //判断是不是文件,如果是文件,就输出文件路径
                System.out.println("文件名:"+f.getAbsolutePath());
            }else{
                //代表是目录,同样也输出目录绝对路径
                System.out.println("目录"+f.getAbsolutePath());
                //继续变能力,访问目录下的子文件和子目录,递归调用
                printDir(f);
            }
        }
    }
}

运行结果:

 总结:

这个例子的关键在于遍历指定文件夹下的文件的方法应该怎么写;

创建File绝对路径对象dir;

 listFile() 得到File类型的数组,File[] files = dir.listFiles(),用增强for循环进行遍历;

判断是否是文件isFile;

如果是文件,直接打印输出文件的绝对路径;

如果是文件夹,则打印文件夹的绝对路径,并在此调用方法本身,直到遍历到文件为止。

注意:D盘下的myjava文件夹中,还有子文件夹,所以要调用方法本身,继续遍历这个子文件夹下的文件,直到把所有文件的绝对路径都输出打印。

方法内部调用方法本身,这种用法叫递归。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
作为AI语言模型,我无法直接操作前端,但是我可以提供一些Java代码来读取文件夹并生成树形结构。具体的前端代码需要根据您所使用的框架和库来实现。 可以使用Java中的File类来读取文件夹。以下是一个示例代码,它将打印出指定文件夹中的所有文件文件夹以及它们的层次结构: ```java import java.io.File; public class DirectoryTree { public static void main(String[] args) { File directory = new File("/path/to/folder"); if (directory.exists()) { printDirectoryTree(directory, 0); } else { System.out.println("Directory not found."); } } private static void printDirectoryTree(File folder, int level) { if (folder.isFile()) { System.out.println(getIndent(level) + "- " + folder.getName()); } else { System.out.println(getIndent(level) + "+ " + folder.getName()); File[] files = folder.listFiles(); if (files != null) { for (File file : files) { printDirectoryTree(file, level + 1); } } } } private static String getIndent(int level) { StringBuilder sb = new StringBuilder(); for (int i = 0; i < level; i++) { sb.append("| "); } return sb.toString(); } } ``` 该代码将以以下形式输出文件夹中的内容: ``` + folder | + subfolder1 | | - file1.txt | | - file2.txt | + subfolder2 | | + subsubfolder1 | | | - file3.txt | | - file4.txt | - file5.txt ``` 您可以将这个代码结合前端框架来实现树形结构。例如,您可以使用React来实现一个归组件,在组件中调用Java代码并将结果渲染为树形结构。以下是一个简单的示例代码: ```jsx import React, { useState, useEffect } from 'react'; function DirectoryTree() { const [tree, setTree] = useState([]); useEffect(() => { fetch('/api/directory') .then(response => response.json()) .then(data => setTree(data)); }, []); function renderTree(node) { if (node.isFile) { return <li>{node.name}</li>; } else { return ( <li> {node.name} <ul>{node.children.map(child => renderTree(child))}</ul> </li> ); } } return <ul>{tree.map(node => renderTree(node))}</ul>; } export default DirectoryTree; ``` 在此示例代码中,我们使用fetch API从后端API中获取树形结构数据,并使用归组件将其渲染为树形结构。在这里,我们假设后端API将数据以以下格式返回: ```json [ { "name": "folder", "isFile": false, "children": [ { "name": "subfolder1", "isFile": false, "children": [ { "name": "file1.txt", "isFile": true }, { "name": "file2.txt", "isFile": true } ] }, { "name": "subfolder2", "isFile": false, "children": [ { "name": "subsubfolder1", "isFile": false, "children": [{ "name": "file3.txt", "isFile": true }] }, { "name": "file4.txt", "isFile": true } ] }, { "name": "file5.txt", "isFile": true } ] } ] ``` 您需要将这个数据格式化为您所需要的格式,并将其作为状态传归组件。根据您的需求,您还可以添加其他功能,例如展开和收缩文件夹搜索文件夹等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值