作者信息:https://home.cnblogs.com/u/huangjiabobk

在Linux中,编写一个shell脚本,用于统计指定目录下所有文件的行数。

编写一个shell脚本,用于统计指定目录下所有文件的行数,可以通过循环遍历目录下的每一个文件并使用wc -l命令来获取每个文件的行数。以下是一个基本示例:

#!/bin/bash
# 用户输入要统计行数的目录路径
read -p "请输入要统计行数的目录路径: " directory
# 避免用户直接输入了文件名而不是目录
if [ ! -d "$directory" ]; then
echo "错误:这不是一个有效的目录!"
exit 1
fi
# 遍历目录下的所有非目录项(即文件)
for file in "$directory"/*
do
# 排除子目录
if [ ! -d "${file}" ]; then
# 获取当前文件的行数
lines=$(wc -l < "${file}")
echo "文件:${file} 行数:${lines}"
fi
done

该脚本首先提示用户输入一个目录路径,然后检查该路径是否确实为一个存在的目录。接下来,通过for循环遍历目录下所有的文件,并利用管道将文件内容传递给wc -l命令,从而得到每个文件的行数。最后,脚本会逐个输出文件名及其对应的行数。

如果你需要包括子目录中的所有文件,可以使用find命令替代for循环:

#!/bin/bash
read -p "请输入要统计行数的目录路径: " directory
if [ ! -d "$directory" ]; then
echo "错误:这不是一个有效的目录!"
exit 1
fi
# 使用find命令递归查找目录下所有普通文件,并统计行数
find "$directory" -type f -exec wc -l {} \; | awk '{print $2, "\t", $1}'

在上述改进版中,find命令加上 -type f 参数以确保只查找文件而非目录,并通过 -exec 参数执行 wc -l 命令处理找到的每个文件。awk用于格式化输出,使其显示为“行数 文件名”的形式。

posted @   黄嘉波  阅读(116)  评论(0编辑  收藏  举报
努力加载评论中...
版权声明:原创作品,谢绝转载!否则将追究法律责任。--作者 黄嘉波
点击右上角即可分享
微信分享提示