程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> C#入門知識 >> C#獲取指定目錄包含的文件和子目錄

C#獲取指定目錄包含的文件和子目錄

編輯:C#入門知識

如何獲取指定目錄包含的文件和子目錄     1. DirectoryInfo.GetFiles():獲取目錄中(不包含子目錄)的文件,返回類型為FileInfo[],支持通配符查找;     2. DirectoryInfo.GetDirectories():獲取目錄(不包含子目錄)的子目錄,返回類型為DirectoryInfo[],支持通配符查找;     3. DirectoryInfo. GetFileSystemInfos():獲取指定目錄下(不包含子目錄)的文件和子目錄,返回類型為FileSystemInfo[],支持通配符查找; 如何獲取指定文件的基本信息;     FileInfo.Exists:獲取指定文件是否存在;     FileInfo.Name,FileInfo.Extensioin:獲取文件的名稱和擴展名;     FileInfo.FullName:獲取文件的全限定名稱(完整路徑);     FileInfo.Directory:獲取文件所在目錄,返回類型為DirectoryInfo;     FileInfo.DirectoryName:獲取文件所在目錄的路徑(完整路徑);     FileInfo.Length:獲取文件的大小(字節數);     FileInfo.IsReadOnly:獲取文件是否只讀;     FileInfo.Attributes:獲取或設置指定文件的屬性,返回類型為FileAttributes枚舉,可以是多個值的組合     FileInfo.CreationTime、FileInfo.LastAccessTime、FileInfo.LastWriteTime:分別用於獲取文件的創建時間、訪問時間、修改時間; --------------------------------- 遍歷文件夾  文件夾是樹形結構,遍歷算法有:廣度優先級和深度優先級。 區別:廣度首先查找同一層目錄,深度首先遍歷一條分支;有了這個區別,就可以確定鏈表的插入位置,即廣度遍歷插入點總在末尾;深度遍歷插入點在首部。詳細看代碼。 public static void searchFile(String path, List<Object> resultList) {   File file = new File(path);   if (file.isDirectory()) {    LinkedList<File[]> levelLinked = new LinkedList<File[]>();    levelLinked.add(file.listFiles());    do {     File[] childFiles = levelLinked.remove(0);     for (File cf : childFiles) {      if (cf.isDirectory()) {       // 此處控制遍歷的方向       levelLinked.add(cf.listFiles());// 廣度       // levelLinked.add(0, cf.listFiles());//深度      } else {       String fileName = cf.getName();// 文件名,有後綴       String filePath = cf.getAbsolutePath();// 絕對路徑       String fileParent = cf.getParent();// 上層路徑,注意最後的'/'       // 比較算法,找到後放入集合       String[] sf = { fileName, fileParent, filePath };       resultList.add(sf);      }     }    } while (levelLinked.size() > 0);   }  } 此處加入一些API提供的工具類,希望有用。 1.多後綴判斷,如.java、.class、.js等 String[] hz = {java,class,js}; Arrays.sort(hz);//下面的搜索需要排序,例如,class的順序在java之前,如果不sort(),class文件不會被查找 Arrays.binarySearch(hz, fn_);//fn_文件後綴 如果明確目錄的層次結構簡單,遞歸算法也是不錯的選擇。 個人覺得,文件的搜索,應該單獨起線程。   //////////////////////// 采用遞歸的方式遍歷,文件夾和子文件中的所有文件。 public void FindFile(string dirPath) //參數dirPath為指定的目錄 {  //在指定目錄及子目錄下查找文件,在listBox1中列出子目錄及文件 DirectoryInfo Dir=new DirectoryInfo(dirPath); try { foreach(DirectoryInfo d in Dir.GetDirectories()//查找子目錄  { FindFile(Dir+d.ToString()+"\"); listBox1.Items.Add(Dir+d.ToString()+"\"); //listBox1中填加目錄名 } foreach(FileInfo f in Dir.GetFiles("*.---")) //查找文件 { listBox1.Items.Add(Dir+f.ToString()); //listBox1中填加文件名 } } catch(Exception e) { MessageBox.Show(e.Message); }   }     用下面代碼限制文件的類型: foreach(FileInfo f in Dir.GetFiles("*.---")) //查找文件     “*.---”指要訪問的文件的類型的擴展名 ///////////////////////////////www.2cto.com 代碼改成如下,會不會好一點   DirectoryInfo TheFolder=new DirectoryInfo(folderFullName);   DirectoryInfo[] dirInfo = TheFolder.GetDirectories(); //遍歷文件夾 foreach(DirectoryInfo NextFolder in dirInfo) this.listBox1.Items.Add(NextFolder.Name);   FileInfo[] fileInfo = TheFolder.GetFiles(); //遍歷文件 foreach(FileInfo Next...

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved