linux中统计目录内的档案数和总容量

以/root目录为例:

1.总容量统计方法:

du -sh /root  

2.总档案数的统计方法

find /root -type f | wc -l

### 如何在 Linux 中通过大小对文件夹进行排序 为了实现按照容量大小对文件夹进行排序的功能,可以结合 `du` `sort` 命令完成此操作。以下是具体方法: #### 使用命令组合 首先利用 `du` 命令统计目录的磁盘占用情况,再借助 `sort` 对其结果按值大小排序。 ```bash du -h --max-depth=1 | sort -hr ``` - 参 `-h` 表示以人类可读的形式显示文件大小 (如 K、M、G)[^1]。 - 参 `--max-depth=1` 限定只计算当前目录下的一级子目录文件的大小。 - 接着使用管道符传递给 `sort` 命令。 - 参 `-h` 让 `sort` 能够理解并处理带有单位的人类可读格式据[^2]。 - 参 `-r` 则指定逆序排列,使得最大的条目位于最上方。 上述指令能够清晰地展示出哪些子目录占用了最多的存储空间,从而帮助管理员有效管理磁盘资源。 #### 示例输出解释 假设运行以上命令后得到如下结果: ``` 8.5G ./data 700M ./logs 300M ./temp ... ``` 这表明名为 `data` 的子目录占据了最多的空间——大约 8.5GB;其次是 `logs` 文件夹约有 700MB 大小等等。 #### 注意事项 当尝试清理大尺寸项目前,请务必确认这些项确实是可以安全移除的内容,以免误删重要资料影响系统正常运作。 ```python import os from subprocess import run, PIPE def get_folder_sizes(path="."): result = run(['du', '-h', '--max-depth=1'], cwd=path, stdout=PIPE) sorted_result = run(['sort', '-hr'], input=result.stdout, text=True) return sorted_result.stdout.splitlines() for line in get_folder_sizes(): print(line) ``` 该 Python 函封装了前面提到的 Shell 操作逻辑,便于集成到更复杂的程序当中去调用执行相同功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值