在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用于格式化输出,使其显示为“行数 文件名”的形式。