如何用find命令按文件大小快速查找并美化输出显示

背景

在系统中使用find命令查找大于20MB的文件非常简单,但默认情况下,输出结果中只显示文件路径,而不显示文件大小。如下图所示:

如果输出中能够同时显示文件大小,并且对内容进行适当的着色,这将显著提高其可读性和实用性。如下图所示:

为了实现这一目标,我们可以通过把命令封装成脚本,使其不仅显示文件路径和大小,还能够对输出进行着色处理。

实现思路

编写这个脚本的思路是首先确保用户输入查找目录和文件大小限制,然后使用find命令查找符合条件的文件,结合ls命令显示文件大小,最后利用 --color选项对输出进行着色处理,以提高可读性和管理效率。

脚本编写

  1. 默认查找目录和文件大小限制:设定默认的查找目录和文件大小限制。
bash 复制代码
SEARCH_DIR="/"
SIZE_LIMIT="+10M"
  1. 获取用户输入的查找目录和文件大小限制 :通过 read 命令提示用户输入查找目录和文件大小限制,如果用户未输入则使用默认值。
shell 复制代码
read -p "请输入查找目录 (默认: /): " USER_SEARCH_DIR
read -p "请输入文件大小限制 (例如: +10M 默认: +10M): " USER_SIZE_LIMIT

if [ -n "$USER_SEARCH_DIR" ]; then
    SEARCH_DIR="$USER_SEARCH_DIR"
fi

if [ -n "$USER_SIZE_LIMIT" ]; then
    SIZE_LIMIT="$USER_SIZE_LIMIT"
fi
  1. 查找大于指定大小的文件,显示文件路径和大小,并进行着色处理 :使用 find 命令查找符合条件的文件,并使用ls命令显示文件大小,同时利用 --color=auto 选项对输出进行着色处理。
bash 复制代码
find "$SEARCH_DIR" -xdev -size "$SIZE_LIMIT" -type f -print0 | xargs -0  ls -Ssh1 --color=auto 

ls -Ssh1:

  • -S:按文件大小排序,最大的文件排在最前面。

  • -s:在每个文件之前显示文件的块大小。

  • -h:以人类可读的方式显示文件大小(例如,使用 K、M、G 等单位)

  • -1:每行只显示一个文件。

以下是命令脚本全部内容:

如何使用

  1. 创建脚本文件 :将上述脚本保存为 find_large_files.sh

  2. 赋予执行权限 :在终端中运行 chmod +x find_large_files.sh

  3. 运行脚本 :执行 ./find_large_files.sh,根据提示输入查找目录和文件大小限制。 如下图所示:

总结

通过这个命令脚本,用户不仅可以轻松查找系统中大于指定大小的文件,还能显示文件的大小,并对输出结果进行着色处理,使得输出更加直观和易读。这种增强的可读性和实用性能够帮助用户更高效地管理文件系统

脚本获取方式


上述脚本已经上传上传到gitee,有需要的小伙伴可以自行获取。gitee上的仓库主要是分享一些工作中常用的脚本。小伙伴可以frok或者watch仓库,这样有更新可以及时关注到。

仓库地址:

shell 复制代码
https://gitee.com/didiplus/script

推荐阅读



相关推荐
JuiceFS14 小时前
从 MLPerf Storage v2.0 看 AI 训练中的存储性能与扩展能力
运维·后端
CYRUS_STUDIO17 小时前
用 Frida 控制 Android 线程:kill 命令、挂起与恢复全解析
android·linux·逆向
熊猫李19 小时前
rootfs-根文件系统详解
linux
chen94520 小时前
mysql 3节点mgr集群部署
运维·后端
LH_R21 小时前
OneTerm开源堡垒机实战(三):功能扩展与效率提升
运维·后端·安全
dessler21 小时前
Hadoop HDFS-高可用集群部署
linux·运维·hdfs
泽泽爱旅行21 小时前
awk 语法解析-前端学习
linux·前端
少妇的美梦2 天前
logstash教程
运维
chen9452 天前
k8s集群部署vector日志采集器
运维
chen9452 天前
aws ec2部署harbor,使用s3存储
运维