Search code examples
c#directorydirectory-listing

How to get the progress of directories traversing


I need to know content of directories with items older than one month. I'm using:

var directories = dir.GetDirectories("*", SearchOption.AllDirectories).Where(fi => fi.CreationTime < lastmonth).ToList();

But I need feedback about progress. Usually directories have thousands of files and sometimes the program seems to be stuck. It is a desktop application searching for old backup files on server. I would like to inform the user which directory is currently being searched.


Solution

  • Only way I know is to recursively go through the folder instead of using SearchOption.AllDirectories. See code below for example. Code below is creating an Xml file of all file/folders. Folder is the root where to start search.

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Xml;
    using System.Xml.Linq;
    using System.IO;
    
    namespace SAveDirectoriesXml
    {
        class Program
        {
            const string FILENAME = @"c:\temp\test.xml";
            const string FOLDER = @"c:\temp";
            static XmlWriter writer = null;
            static void Main(string[] args)
            {
                XmlWriterSettings settings = new XmlWriterSettings();
                settings.Indent = true;
    
                writer = XmlWriter.Create(FILENAME, settings);
                writer.WriteStartDocument(true);
    
                DirectoryInfo info = new DirectoryInfo(FOLDER);
                WriteTree(info);
                
                writer.WriteEndDocument();
                writer.Flush();
                writer.Close();
                Console.WriteLine("Enter Return");
                Console.ReadLine();
    
            }
            static long WriteTree(DirectoryInfo info)
            {
                long size = 0;
                writer.WriteStartElement("Folder");
                try
                {
                    writer.WriteAttributeString("name", info.Name);
                    writer.WriteAttributeString("numberSubFolders", info.GetDirectories().Count().ToString());
                    writer.WriteAttributeString("numberFiles", info.GetFiles().Count().ToString());
                    writer.WriteAttributeString("date", info.LastWriteTime.ToString());
                 
    
                    foreach (DirectoryInfo childInfo in info.GetDirectories())
                    {
                        size += WriteTree(childInfo);
                    }
                    
                }
                catch (Exception ex)
                {
                    string errorMsg = string.Format("Exception Folder : {0}, Error : {1}", info.FullName, ex.Message);
                    Console.WriteLine(errorMsg);
                    writer.WriteElementString("Error", errorMsg);
                }
    
                FileInfo[] fileInfo = null;
                try
                {
                    fileInfo = info.GetFiles();
                }
                catch (Exception ex)
                {
                    string errorMsg = string.Format("Exception FileInfo : {0}, Error : {1}", info.FullName, ex.Message);
                    Console.WriteLine(errorMsg);
                    writer.WriteElementString("Error",errorMsg);
                }
    
                if (fileInfo != null)
                {
                    foreach (FileInfo finfo in fileInfo)
                    {
                        try
                        {
                            writer.WriteStartElement("File");
                            writer.WriteAttributeString("name", finfo.Name);
                            writer.WriteAttributeString("size", finfo.Length.ToString());
                            writer.WriteAttributeString("date", info.LastWriteTime.ToString());
                            writer.WriteEndElement();
                            size += finfo.Length;
                        }
                        catch (Exception ex)
                        {
                            string errorMsg = string.Format("Exception File : {0}, Error : {1}", finfo.FullName, ex.Message);
                            Console.WriteLine(errorMsg);
                            writer.WriteElementString("Error", errorMsg);
                        }
                    }
                }
    
                writer.WriteElementString("size", size.ToString());
                writer.WriteEndElement();
                return size;
    
            }
        }
    }
    Share
    Edit