今天,头给了个任务:写个方法,我会给你个路径,计算这个路径所占用的磁盘空间 。

然后,找了很多资料。但大部分都是获取文件夹/文件的大小的。对于占用空间的没有成品代码。(ps:我没找到。)后来,在网上找了些资料,自己捣鼓出来了。在这里记录下,一则说不定以后能用到。再则如果有高手有更好的方法或者建议,求指点。

废话不多说了。begin。

首先说下文件夹/文件大小与占用空间的区别。

这个是硬盘分区格式有关 大小是文件的实际大小,而占用空间是占硬盘的实际空间 以FAT32格式为例,硬盘的基本存储单位是簇,在FAT32中一簇是4KB 那么,也就是说即使文件只有1个字节,在硬盘上也要占到4KB的空间 如果文件是4KB零1个字节,那就要占用8KB的空间,以此类推 结论: 大小是文件的实际大小,而占用空间是占硬盘的实际空间。(ps:偷了一下懒,直接百度知道了。)

那么问题来了。怎样获取本机的簇有多少字节呢?

首先通过windows API获取磁盘的相关信息。

//调用windows API获取磁盘空闲空间
//导入库
[DllImport("kernel32.dll", CharSet = CharSet.Auto)]
static extern bool GetDiskFreeSpace([MarshalAs(UnmanagedType.LPTStr)]string rootPathName,
ref int sectorsPerCluster, ref int bytesPerSector, ref int numberOfFreeClusters, ref int totalNumbeOfClusters);

  下面是具体代码。第一次写文章就简单点了。

/// <summary>
/// 获取指定路径的大小
/// </summary>
/// <param name="dirPath">路径</param>
/// <returns></returns>
public static long GetDirectoryLength(string dirPath)
{
    long len = 0;
    //判断该路径是否存在(是否为文件夹)
    if (!Directory.Exists(dirPath))
    {
        //查询文件的大小
        len = FileSize(dirPath);
    }
    else
    {
        //定义一个DirectoryInfo对象
        DirectoryInfo di = new DirectoryInfo(dirPath);
         
        //通过GetFiles方法,获取di目录中的所有文件的大小
        foreach (FileInfo fi in di.GetFiles())
        {
            len += fi.Length;
        }
        //获取di中所有的文件夹,并存到一个新的对象数组中,以进行递归
        DirectoryInfo[] dis = di.GetDirectories();
        if (dis.Length > 0)
        {
            for (int i = 0; i < dis.Length; i++)
            {
                len += GetDirectoryLength(dis[i].FullName);
            }
        }
    }
    return len;
}
 
/// <summary>
/// 获取指定路径的占用空间
/// </summary>
/// <param name="dirPath">路径</param>
/// <returns></returns>
public static long GetDirectorySpace(string dirPath)
{
    //返回值
    long len = 0;
    //判断该路径是否存在(是否为文件夹)
    if (!Directory.Exists(dirPath))
    {
        //如果是文件,则调用
        len = FileSpace(dirPath);
    }
    else
    {
        //定义一个DirectoryInfo对象
        DirectoryInfo di = new DirectoryInfo(dirPath);
        //本机的簇值
        long clusterSize = GetClusterSize(di);
        //遍历目录下的文件,获取总占用空间
        foreach (FileInfo fi in di.GetFiles())
        {
            //文件大小除以簇,余若不为0
            if (fi.Length % clusterSize != 0)
            {
                decimal res = fi.Length / clusterSize;
                //文件大小除以簇,取整数加1。为该文件占用簇的值
                int clu = Convert.ToInt32(Math.Ceiling(res)) + 1;
                long result = clusterSize * clu;
                len += result;
            }
            else
            {
                //余若为0,则占用空间等于文件大小
                len += fi.Length;
            }
        }
        //获取di中所有的文件夹,并存到一个新的对象数组中,以进行递归
        DirectoryInfo[] dis = di.GetDirectories();
        if (dis.Length > 0)
        {
            for (int i = 0; i < dis.Length; i++)
            {
                len += GetDirectorySpace(dis[i].FullName);
            }
        }
    }
    return len;
}
 
//所给路径中所对应的文件大小
public static long FileSize(string filePath)
{
    //定义一个FileInfo对象,是指与filePath所指向的文件相关联,以获取其大小
    FileInfo fileInfo = new FileInfo(filePath);
    return fileInfo.Length;
}
 
//所给路径中所对应的文件占用空间
public static long FileSpace(string filePath)
{
    long temp = 0;
    //定义一个FileInfo对象,是指与filePath所指向的文件相关联,以获取其大小
    FileInfo fileInfo = new FileInfo(filePath);
    long clusterSize = GetClusterSize(fileInfo);
    if (fileInfo.Length % clusterSize != 0)
    {
        decimal res = fileInfo.Length / clusterSize;
        int clu = Convert.ToInt32(Math.Ceiling(res)) + 1;
        temp = clusterSize * clu;
    }
    else
    {
        return fileInfo.Length;
    }
    return temp;
}
 
public static DiskInfo GetDiskInfo(string rootPathName)
{
    DiskInfo diskInfo = new DiskInfo();
    int sectorsPerCluster = 0, bytesPerSector = 0, numberOfFreeClusters = 0, totalNumberOfClusters = 0;
    GetDiskFreeSpace(rootPathName, ref sectorsPerCluster, ref bytesPerSector, ref numberOfFreeClusters, ref totalNumberOfClusters);
 
    //每簇的扇区数
    diskInfo.SectorsPerCluster = sectorsPerCluster;
    //每扇区字节
    diskInfo.BytesPerSector = bytesPerSector;
 
    return diskInfo;
}
 
//// <summary>
/// 结构。硬盘信息
/// </summary>
public struct DiskInfo
{
    public string RootPathName;
    //每簇的扇区数
    public int SectorsPerCluster;
    //每扇区字节
    public int BytesPerSector;
    public int NumberOfFreeClusters;
    public int TotalNumberOfClusters;
}
/// <summary>
/// 获取每簇的字节
/// </summary>
/// <param name="file">指定文件</param>
/// <returns></returns>
public static long GetClusterSize(FileInfo file)
{
    long clusterSize = 0;
    DiskInfo diskInfo = new DiskInfo();
    diskInfo = GetDiskInfo(file.Directory.Root.FullName);
    clusterSize = (diskInfo.BytesPerSector * diskInfo.SectorsPerCluster);
    return clusterSize;
}
 
/// <summary>
/// 获取每簇的字节
/// </summary>
/// <param name="dir">指定目录</param>
/// <returns></returns>
public static long GetClusterSize(DirectoryInfo dir)
{
    long clusterSize = 0;
    DiskInfo diskInfo = new DiskInfo();
    diskInfo = GetDiskInfo(dir.Root.FullName);
    clusterSize = (diskInfo.BytesPerSector * diskInfo.SectorsPerCluster);
    return clusterSize;
}

C#获取文件夹/文件的大小以及占用空间 转摘自:http://www.cnblogs.com/chenpeng-dota/articles/2176470.html的更多相关文章

  1. JavaSE 文件递归之删除&amp;获取文件夹文件夹中全部的以.jpg的文件的绝对路径

    1.递归删除文件 假设一个文件夹以下还有子文件夹,进行删除的话会 报错,这个时候要使用递归的方式来删除这个文件文件夹中的全部文件以及文件夹 package cn.itcast.digui; impor ...

  2. AJPFX:实现递归统计文件夹的总大小

    class Statistical {    public static void main(String[] args) {        Scanner sc = new Scanner(Syst ...

  3. linux如何查看目录或文件夹的总大小--du命令

    记录一下如何查看一个目录或文件夹的总大小. 使用du命令的选项-s,可以统计整个目录或文件夹的大小. 例如 du -sk ./ 156k -k表示以KB为单位计算.

  4. java基础IO删除文件夹文件

    /** * 定义一个方法,能够删除任意文件夹,文件夹路径由键盘录入 注意:不要在C盘下做测试,请选定无用的文件夹测试! */ 1.键盘录入 private static File getfile() ...

  5. java实现基于关键字的文件夹(文件)的搜索、文件夹(文件)的复制、删除

    最近在做一个项目,需要实现这几项功能,上网查了很多资料,自己研究了好几天终于实现了,现在与大家分享一下. 一.JAVA实现文件夹的搜索   在百度搜索N个技术文章,从哪些大牛们共享的资料中终于写出了我 ...

  6. python 遍历文件夹 文件

    python 遍历文件夹 文件   import os import os.path rootdir = "d:\data" # 指明被遍历的文件夹 for parent,dirn ...

  7. android多国语言文件夹文件汇总

    android多国语言文件夹文件汇总如下: 中文(中国):values-zh-rCN 中文(台湾):values-zh-rTW 中文(香港):values-zh-rHK 英语(美国):values-e ...

  8. PHP文件夹文件拷贝/复制函数 dir_copy($src = '', $dst = '')

    /* * 文件夹文件拷贝 * * @param string $src 来源文件夹 * @param string $dst 目的地文件夹 * @return bool */ function dir ...

  9. Shell脚本递归打印指定文件夹中全部文件夹文件

    #!/bin/bash #递归打印当前文件夹下的全部文件夹文件. PRINTF() { ls $1 | while read line #一次读取每一行放到line变量中 do [ -d $1/$li ...

随机推荐

  1. git兼容svn与hg功能

    本地.git库 远程:push  提交以后push才可以到远程库

  2. Vue----v-if 条件渲染

    先看一个使用vue v-if的小例子 <div id="example"> <p>小明和小李和小新,小月正在捉迷藏此时</p> <p> ...

  3. spring 整合rabbitMQ

    <!-- 配置邮件消息队列监听 --> <bean id="maillistener" class="cn.xdf.wlyy.listener.Mail ...

  4. 【python实例】统计字符串里大写字母,小写字母的个数和非字母的个数

    """ 给定一个以下字符串:统计大写字母的个数,小写字母的个数,非字母的个数. str1 = "ajdkkKDKEK1343KFKiriromfkfKKRIOW ...

  5. vue中使用canvas绘制签名

    不多说,上代码: <template>         <div class="sign-canvas">             <canvas   ...

  6. Python 递归算法指归

    1. 递归概述 递归( recursion)是一种编程技巧,某些情况下,甚至是无可替代的技巧.递归可以大幅简化代码,看起来非常简洁,但递归设计却非常抽象,不容易掌握.通常,我们都是自上而下的思考问题, ...

  7. 【leetcode】592. Fraction Addition and Subtraction

    题目如下: 解题思路:本题考察的是分数的加减法.小学时候就学过,分数的加减法是先求两个分母的最小公倍数,然后分子分别乘以最小公倍数与自己分母的商,相加后约分即可.所以,本题只要按+,-两个符号分割输入 ...

  8. 微信小程序上拉加载下拉刷新

    微信小程序实现上拉加载下拉刷新 使用小程序默认提供方法. (1). 在xxx.json 中开启下拉刷新,需要设置backgroundColor,或者是backgroundTextStyle ,因为加载 ...

  9. 【LeetCode 75】颜色分类

    题目链接 [题解] 维护一个左边界l和一个右边界r 其中0..l-1都是'0' 而 r+1..n-1都是'2' 我们令i=l;i<=r; 枚举每一个a[i]; ①如果a[i]=2.那么把a[i] ...

  10. paper 168: 2018-FATTEN 论文解析-feature space transfer for data augmentation

    paper download:https://arxiv.org/abs/1801.04356 本文的核心就是使用GAN网络生成新的数据. 这个总体框图,常规结构,具体是通过在appearance和p ...