作者信息: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 @ 2024-03-17 22:31  黄嘉波  阅读(98)  评论(0编辑  收藏  举报
版权声明:原创作品,谢绝转载!否则将追究法律责任。--作者 黄嘉波