利用shell脚本遍历文件夹内所有的文件并作整理统计的方法

所属分类: 脚本专栏 / linux shell 阅读数: 639
收藏 0 赞 0 分享

环境: Ubuntu下采用shell脚本实现

案例简述: 文件夹内有许多子文件夹,这里需要自动读取所有的文件,包括他们的地址和文件名。通过观察文件名的规律,按照一定的规则裁剪出文件名的某一部分,该部分为数字,则根据数字的大小统计该文件夹内文件在各个数据段的数量。

1.这里写一个函数,实现对文件夹内所有文件名的读取,采用的方法是递归!

#!/bin/bash
#folder="./test"

function readfile ()
{
#这里`为esc下面的按键符号
 for file in `ls $1`
 do
#这里的-d表示是一个directory,即目录/子文件夹
 if [ -d $1"/"$file ]
 then
#如果子文件夹则递归
  readfile $1"/"$file
 else
#否则就能够读取该文件的地址
  echo $1"/"$file
#读取该文件的文件名,basename是提取文件名的关键字
 echo `basename $file`
 fi
 done
}
#函数定义结束,这里用来运行函数
folder="./test"
readfile $folder 

2.这里实验了初始化变量和变量赋值

#!/bin/bash
a=002
#打印a的值
echo $a
#注意这里赋初始值不能有空格
b=20
c=30
#注意这里[]和符号及字母之间一定要有空格,否则错误!
#这里shell脚本的逻辑运算-a表示与运算,-o表示或运算,!表示否运算
#-lt表示小于,-gt表示大于,-eq表示等于,-ne表示不等于,-le表示小于等于,-ge表示大于等于
if [ $a -lt $b -a $a -gt $c ]
then
#这里赋值注意两个括号,等号两边不能留有空隙
a=$(($a + 2))
a=$(($a + 1))
a=$(($a+ 4))
echo "hehe!"
elif [ $a -lt $b ]
then
echo $(($a + 100))
a=$(($a + 12))
echo "a is:"$a
echo "hello world!"
else
echo "i dont know"
fi  

3.综合实验

#!/bin/bash
#echo "start..."
#define a function to read all the files in the folder
#赋初始值
a10=0
a20=0
a30=0
a40=0
a50=0
a60=0
a70=0

#定义读取文件名的函数
function readfile ()
{
 for file in `ls $1`
 do
 if [ -d $1"/"$file ]
 then
#这里采用递归的方法来读取文件名
  readfile $1"/"$file
 else
#这一步使得temp变量获得文件名
  temp=`basename $file`
#echo $temp
#这里需要注意##*。。表示删除字符串最右边。。及其左边所有内容
var=${temp##*M}
#%。。*表示删除字符串左边的。。及其右边的内容!两个%%则表示最左边
var1=${var%.*}
var2=${var1%a*}
var3=${var2%b*}
var4=${var3%c*}
var5=${var4%d*}
var6=${var5%e*}
var7=${var6%f*}
var8=${var7%g*}
#echo $var8

#if 和括号之间必须有空格
if [ $var8 -le 10 ]
then
a10=$(($a10 + 1))
elif [ $var8 -gt 10 -a $var8 -le 20 ]
then
a20=$(($a20 + 1))
elif [ $var8 -gt 20 -a $var8 -le 30 ]
then
a30=$(($a30 + 1))
elif [ $var8 -gt 30 -a $var8 -le 40 ]
then
a40=$(($a40 + 1))
elif [ $var8 -gt 40 -a $var8 -le 50 ]
then
a50=$(($a50 + 1))
elif [ $var8 -gt 50 -a $var8 -le 60 ]
then
a60=$(($a60 + 1))
else 
a70=$(($a70 + 1))
fi
fi
#echo $var8
done
#echo $a40
}
folder="/home/cc/Age/data/MORPH"
readfile $folder 
#打印出每个数字段的个数
echo $a10
echo $a20
echo $a30
echo $a40
echo $a50
echo $a60
echo $a70 

这里将该脚本保存为1.sh,在执行的时候如果用指令sh 1.sh则会报里面内容或者语法出错。笔者为此迷惑了很久,最终查找资料找到的解决办法是:

a) 首先,使sh文件为可执行文件,命令: chmod +x 1.sh;

b) 然后在终端直接执行./1.sh就可以执行。

以上这篇利用shell脚本遍历文件夹内所有的文件并作整理统计的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

更多精彩内容其他人还在看

linux whatis与whatis database 使用及查询方法(man使用实例)

在学习man命令时候,估计很多朋友都发现有man –f ,man –k 参数,可以查出很多数据。这些有的与man手册页相同,有些不是属于手册页的。它们数据怎么收集来的,并且whatis是怎么样工作的
收藏 0 赞 0 分享

linux dev 常见特殊设备介绍与应用(loop,null,zero,full,random)

这篇文章主要介绍了linux dev 常见特殊设备介绍与应用(loop,null,zero,full,random),需要的朋友可以参考下
收藏 0 赞 0 分享

linux shell命令快捷获得系统帮助(一)[man-pages定义规范]

linux命令帮助,一般有2种,命令自身代码里面带有使用帮助说明,这种一般很精简,太长了,程序自身的大小以及日常维护不方便。还有一种,就是带有帮助文件,类似windows的chm格式文件。下面我说下这2种怎么样查阅
收藏 0 赞 0 分享

linux shell实现随机数几种方法分享(date,random,uuid)

这篇文章主要介绍了linux shell实现随机数多种方法(date,random,uuid),需要的朋友可以参考下
收藏 0 赞 0 分享

linux shell 脚本实现tcp/upd协议通讯(重定向应用)

这篇文章主要介绍了linux shell 脚本实现tcp/upd协议通讯(重定向应用),需要的朋友可以参考下
收藏 0 赞 0 分享

linux shell数据重定向(输入重定向与输出重定向)详细分析

这篇文章主要介绍了linux shell数据重定向(输入重定向与输出重定向)详细分析,需要的朋友可以参考下
收藏 0 赞 0 分享

linux shell 管道命令(pipe)使用及与shell重定向区别

这篇文章主要介绍了linux shell 管道命令(pipe)使用及与shell重定向区别,需要的朋友可以参考下
收藏 0 赞 0 分享

Linux下使用tcpdump抓包的实现方法

tcpdump是Linux下面的一个开源的抓包工具,和Windows下面的wireshark抓包工具一样, 支持抓取指定网口、指定目的地址、指定源地址、指定端口、指定协议的数据。这篇文章主要介绍了Linux下使用tcpdump抓包的实现方法,需要的朋友可以参考下
收藏 0 赞 0 分享

零基础入门篇之Linux及Arm-Linux程序开发笔记

这篇文章主要介绍了零基础入门篇之Linux及Arm-Linux程序开发笔记,需要的朋友可以参考下
收藏 0 赞 0 分享

Linux 中 CURL常用命令详解

这篇文章主要介绍了Linux 中 CURL常用命令详解,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多