编写一个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}' BASH 复制 全屏
在上述改进版中,find
命令加上 -type f
参数以确保只查找文件而非目录,并通过 -exec
参数执行 wc -l
命令处理找到的每个文件。awk用于格式化输出,使其显示为“行数 文件名”的形式。