獲取資料夾及其子資料夾下的所有檔案

iDotNetSpace發表於2009-10-19

在公司做的事情比較雜,經常會有一些公司網站的頁面檔案需要修改。因為有些修改時涉及到所有htm頁面檔案,而且內容是相同的,但是檔案數量達到幾千。如果手動更新的話那還不得累慘啊?幸好我們是程式設計師,哪能那麼笨手動去修改呢!所有就寫了一個後臺管理程式。

      如果批量修改的話就需要找到網站根目錄下的所有檔案,包括子資料夾中的檔案。如下就是如何得到資料夾及其子資料夾下的所有檔案的實現程式碼:

public class FileAccess
    {

        //儲存所有資料夾名
        private ArrayList dirs;

        public FileAccess()
        {
            dirs = new ArrayList();
        }

        //獲取所有檔名
        private ArrayList GetFileName(string dirPath)
        {
            ArrayList list = new ArrayList();

            if (Directory.Exists(dirPath))
            {
                list.AddRange(Directory.GetFiles(dirPath));
            }
            return list;
        }

        //獲取所有資料夾及子資料夾
        private void GetDirs(string dirPath)
        {
            if (Directory.GetDirectories(dirPath).Length > 0)
            {
                foreach (string path in Directory.GetDirectories(dirPath))
                {
                    dirs.Add(path);
                    GetDirs(path);
                }
            }
        }

        ///


        /// 獲取給出資料夾及其子資料夾下的所有檔名
        /// (檔名為路徑加檔名及字尾,
        /// 使用的時候GetAllFileName().ToArray()方法可以轉換成object陣列
        /// 之後再ToString()分別得到檔名)
        ///

        /// 資料夾根目錄
        ///
        public ArrayList GetAllFileName(string rootPath)
        {
            dirs.Add(rootPath);
            GetDirs(rootPath);
            object[] allDir = dirs.ToArray();

            ArrayList list = new ArrayList();

            foreach (object o in allDir)
            {
                list.AddRange(GetFileName(o.ToString()));
            }

            return list;
        }

        ///


        /// 如果上個方法不知道怎麼用,那就呼叫這個方法吧
        ///

        ///
        ///
        public List FileName(string rootPath)
        {
            List list = new List();

            foreach (object o in GetAllFileName(rootPath).ToArray())
            {
                list.Add(o.ToString());
            }
            return list;
        }
    }

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/12639172/viewspace-616850/,如需轉載,請註明出處,否則將追究法律責任。

相關文章