C#遍历目录树的 递归

DirectoryInfo   di=new   DirectoryInfo(strBaseDir);//strBaseDir是起始目录,绝对地址   
  DirectoryInfo[]   diA=di.GetDirectories();//获得了所有一级子目录   
  FileInfo[]   fiA=di.GetFiles();//获得了所有起始目录下的文件


获得某一目录下的所有文件和目录(包含所有子目录)
public   ArrayList   al=new   ArrayList();   
  //我把ArrayList当成动态数组用,非常好用   
  public   void   GetAllDirList(string   strBaseDir)   
  {   
        DirectoryInfo   di=new   DirectoryInfo(strBaseDir);   
        DirectoryInfo[]   diA=di.GetDirectories();   
        for(int   i=0;i<diA.Length;i++)   
        {   
          al.Add(diA[i].FullName);   
          //diA[i].FullName是某个子目录的绝对地址,把它记录在ArrayList中   
          GetAllDirList(diA[i].FullName);   
          //注意:递归了。逻辑思维正常的人应该能反应过来   
        }   
  }   
      
  最后,如何把所有目录信息从ArrayList中取出来呢?如下:   
  for(int   i=0;i<al.Count;i++)   
  {   
          textBox1.AppendText(al[i].ToString()+"/n");   
          //textBox1是容器,拷贝我的代码,注意要换一个你自己的容器   
  }   
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值