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

然后,找了很多资料。但大部分都是获取文件夹/文件的大小的。对于占用空间的没有成品代码。(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. RabbitMQ ——消息属性Properties

    简介 发送消息可以为消息指定一些参数 Delivery mode: 是否持久化,1 - Non-persistent,2 - Persistent Headers:Headers can have a ...

  2. 微信小程序(18)-- 自定义头部导航栏

    最近做的项目涉及相应的页面显示相应的顶部标题,所以就需要自定义头部导航了. 首先新建一个顶部导航公用组件topnav,导航高度怎么计算? 1.wx.getSystemInfo 和 wx.getSyst ...

  3. python常用函数 S

    slice(int,int) 切片,可以为切片命名增加可读性. 例子: sorted(iterable, key) 排序,支持传入参数,例如通过itemgetter传入参数(itemgetter可以传 ...

  4. [BZOJ5428][九省联考2018]双木棋

    去年觉得高不可攀的题啊... 貌似就很沙茶了QAQ 直接状压每一行是多少然后合法状态是LIS状态数极少所以随便dp一下就好了啊... 注意初值啥的得赋对才行QAQ 我菜死了 //Love and Fr ...

  5. python基础:9.深拷贝存储双字典

    # 双层循环 temp = list() for i in range(1,100): item = {} itme["a"] = i for j in range(1,100): ...

  6. 【leetcode】1007. Minimum Domino Rotations For Equal Row

    题目如下: In a row of dominoes, A[i] and B[i] represent the top and bottom halves of the i-th domino.  ( ...

  7. 前端-使用template-web.js【模版引擎】渲染数据

    通过ajax请求到的数据,使用传统的拼接字符串也可以做到,但是‘ “ ” ‘这种模式,单引号.双引号容易 扩错,新手入门推荐使用这种,初入前端,需要一个一个敲代码体会一下. 使用 template.j ...

  8. Apache Flink 的迁移之路,2 年处理效果提升 5 倍

    一.背景与痛点 在 2017 年上半年以前,TalkingData 的 App Analytics 和 Game Analytics 两个产品,流式框架使用的是自研的 td-etl-framework ...

  9. 阿里云HPC助力新制造 | 上汽仿真计算云SSCC

    随着上汽集团与阿里云的合作开展,阿里云各项技术逐步深入到上汽汽车研发领域的核心业务实现落地.其中上海汽车集团股份有限公司乘用车分公司(以下简称上汽乘用车)与阿里云共建的仿真计算混合云就是新制造产业升级 ...

  10. Spring学习总结(2)- AOP

    一,什么是AOP AOP(Aspect Oriented Programming)意为:面向切面编程,通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术.AOP是OOP的延续,是软件开发中 ...