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

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

編輯:關於ASP.NET

     如何獲取指定目錄包含的文件和子目錄
    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("*.---")) //查找文件


    “*.---”指要訪問的文件的類型的擴展名
    ///////////////////////////////
    代碼改成如下,會不會好一點

    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