Gets the size of all files within a directory : Directory « File Stream « C# / C Sharp






Gets the size of all files within a directory

     
/*
Copyright (c) 2010 <a href="http://www.gutgames.com">James Craig</a>

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.*/

#region Usings
using System;
using System.Collections.Generic;
using System.IO;
using System.Net;
using System.Text;

#endregion

namespace Utilities
{
    public static class FileManager
    {
        /// <summary>
        /// Determines if a directory exists
        /// </summary>
        /// <param name="DirectoryPath">Path of the directory</param>
        /// <returns>true if it exists, false otherwise</returns>
        public static bool DirectoryExists(string DirectoryPath)
        {
            try
            {
                return Directory.Exists(DirectoryPath);
            }
            catch (Exception a)
            {
                throw a;
            }
        }
        /// <summary>
        /// Gets a list of files
        /// </summary>
        /// <param name="DirectoryPath">Directory to check for files</param>
        /// <param name="Recursive">Determines if this is a recursive look at all directories under this one</param>
        /// <returns>a list of files</returns>
        public static List<FileInfo> FileList(string DirectoryPath,bool Recursive)
        {
            try
            {
                if (!Recursive)
                {
                    return FileList(DirectoryPath);
                }
                List<FileInfo> Files = new List<FileInfo>();
                if (DirectoryExists(DirectoryPath))
                {
                    DirectoryInfo Directory = new DirectoryInfo(DirectoryPath);
                    FileInfo[] SubFiles = Directory.GetFiles();
                    foreach (FileInfo SubFile in SubFiles)
                    {
                        Files.Add(SubFile);
                    }
                    DirectoryInfo[] SubDirectories = Directory.GetDirectories();
                    foreach (DirectoryInfo SubDirectory in SubDirectories)
                    {
                        List<FileInfo> TempFiles = FileList(SubDirectory.FullName, Recursive);
                        foreach (FileInfo File in TempFiles)
                        {
                            Files.Add(File);
                        }
                    }
                }
                return Files;
            }
            catch (Exception a)
            {
                throw a;
            }
        }        
        /// <summary>
        /// Gets a list of files
        /// </summary>
        /// <param name="DirectoryPath">Directory to check for files</param>
        /// <returns>a list of files</returns>
        public static List<FileInfo> FileList(string DirectoryPath)
        {
            try
            {
                List<FileInfo> Files = new List<FileInfo>();
                if (DirectoryExists(DirectoryPath))
                {
                    DirectoryInfo Directory = new DirectoryInfo(DirectoryPath);
                    FileInfo[] SubFiles = Directory.GetFiles();
                    foreach (FileInfo SubFile in SubFiles)
                    {
                        Files.Add(SubFile);
                    }
                }
                return Files;
            }
            catch (Exception a)
            {
                throw a;
            }
        }
        /// <summary>
        /// Gets the size of all files within a directory
        /// </summary>
        /// <param name="Directory">Directory path</param>
        /// <param name="Recursive">determines if this is a recursive call or not</param>
        /// <returns></returns>
        public static long GetDirectorySize(string Directory, bool Recursive)
        {
            try
            {
                long Size = 0;
                List<FileInfo> Files = FileManager.FileList(Directory, Recursive);
                foreach (FileInfo File in Files)
                {
                    Size += File.Length;
                }
                return Size;
            }
            catch (Exception a)
            {
                throw a;
            }
        }
    }
}

   
    
    
    
    
  








Related examples in the same category

1.Find Files That Match a Wildcard Expression
2.Get Files from a directory
3.Get Directory properties from DirectionInfo class
4.Get directory name and file information in that directory
5.Directory Counter
6.File Search
7.Get Name, Parent, Exists properties from DirectoryInfo class
8.Get Creation Time
9.Get Last Write Time
10.Get Last Access Time
11.Calculate Directory Size
12.Copy Directory
13.Check the Existance of a Directory
14.Get Current Directory
15.Set Current Directory
16.Traversing DirectoriesTraversing Directories
17.Directory Object
18.illustrates recursive Directory useillustrates recursive Directory use
19.illustrates the Directory classillustrates the Directory class
20.illustrates the Directory class 2illustrates the Directory class 2
21.Uses the DirectoryInfo class to recursively show subdirectoriesUses the DirectoryInfo class to recursively show subdirectories
22.Changes the current working directory and then lists the files in the directoryChanges the current working directory and then lists the files in the directory
23.Directory Tree HostDirectory Tree Host
24.Determine if the directory is empty, ie. no files and no sub-directories
25.Get an array of files info from a directory.
26.Removes a directory as best as it can. Errors are ignored.
27.Directory Class xxposes static methods for creating, moving, and enumerating through directories and subdirectories.
28.Calculates the size of a directory and its subdirectories, if any, and displays the total size in bytes.
29.Gets the current working directory of the application.
30.Directory Class
31.Calculate the size of a directory and its subdirectories, if any, and displays the total size in bytes.
32.Creates all directories and subdirectories in the specified path.
33.Create new nested directories
34.Deletes an empty directory from a specified path.
35.Deletes the directory any subdirectories and files in the directory.
36.Returns an enumerable collection of directory names in a specified path.
37.Returns an enumerable collection of directory names that match a search pattern in a specified path.
38.Get collection of directory names that match a search pattern, and optionally searches subdirectories.
39.Returns an enumerable collection of file names in a specified path.
40.Returns an enumerable collection of file names that match a search pattern in a specified path.
41.Get a collection of file names that match a search pattern, and optionally searches subdirectories.
42.Determines whether the given path refers to an existing directory on disk.
43.Gets a DirectorySecurity object that encapsulates the access control list (ACL) entries
44.Gets the creation date and time of a directory.
45.Gets the creation date and time, in Coordinated Universal Time (UTC) format, of a directory.
46.Gets the names of subdirectories in the specified directory.
47.Gets an array of directories matching the specified search pattern from the current directory.
48.Returns the volume information, root information, or both for the specified path.
49.Returns the names of files that match the specified search pattern
50.Returns the names of all files and subdirectories in the specified directory.
51.Returns the date and time the specified file or directory was last accessed.
52.Returns the date and time the specified file or directory was last written to.
53.Sets the date and time the specified file or directory was last accessed.
54.Sets the date and time a directory was last written to.
55.Instance methods for creating, moving, and enumerating through directories and subdirectories.
56.Copy directories with DirectoryInfo
57.DriveInfo Class Provides access to information on a drive.
58.Read and Write to a Newly Created Data File
59.Read Text from a File
60.File.OpenText returns a StreamReader
61.Write Text to a File
62.Copy,delete file and directory
63.Find all files in a directory, and all files within every nested directory.
64.Find all files in a directory, and all files within every nested directory. (2)
65.Current Dir
66.Directory Walker
67.Create Directory
68.Class, which describes folder with its subfolders.