java File 遍历某路径下的文件和文件夹操作

本文详细介绍了Java中File类的基本操作,包括遍历文件和目录、获取文件信息等,并提供了实例代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这篇博客写的很好!!!!JAVA中的文件及目录处理类--File

》》》》》》》》》》》》》》》》》》》》》

对java FIle 的操作不是很熟悉,今天要实现在项目中上传图片,大体上是两种方式存到数据库,存在路径下指定路径,前者做过了,今天是用的后者方式。

然后在目录文件夹文件名上有点受阻,File类没怎么用过。

这里只记录几个小方法:

我们要遍历所有的路径,需要使用到 java.io.File 类,该类中有一个方法 File[] listFiles(); 可以返回该文件下面所包含的所有子文件, String getPath(); 返回文件的全名称(包括路径), String getName();  返回文件名。
首先,我们先来遍历一下 D 盘根目录下所有的子文件:
public static void fileList() {
        File file=new File("d:/");
        File[] files = file.listFiles();
        if (files != null) {
              for (File f : files) {
                    System.out.println(f.getPath());
              }
        }
   }


如果我们需要遍历 D 盘下所有的文件和文件夹,而不是根目录下的文件夹,这个时候我们需要使用到递归:
public static void fileList(File file) {
        File[] files = file.listFiles();
        if (files != null) {
              for (File f : files) {
                    System.out.println(f.getPath());
                    fileList(f);
              }
        }
   }


然后在主函数中调用:
</pre><span style="font-size: 14pt;">public static void main(String[] args) {</span></div><pre name="code" class="java">

        File file=new File("d:/");
        fileList(file);
   }


然后,输出的都是全路径,我们可以对我们的递归函数做如下改进:
   public static void fileList(File file,int node) {
        node++;
        File[] files = file.listFiles();
        if (files != null) {
              for (File f : files) {
                    for(int i=0;i<node;i++){
                         if(i==node-1){
                               System.out.print("├");
                         }
                         else{
                               System.out.print(" ");
                         }
                    }
                    System.out.println(f.getName());
                    fileList(f,node);
              }
        }
   }


然后再次在主函数中调用:
public static void main(String[] args) {
        File file=new File("d:/");
        fileList(file,0);
   }

得到的结果是一个类似树状的结构,如果你对此还不满意,可以尝试给 JTree 上添加节点,可以做到和资源管理器中一样的结构。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值