您的位置:首页 > 运维架构 > Shell

1.shell实用脚本:批量拷贝相同类型的文件

2016-05-16 09:57 555 查看

批量拷贝相同类型的文件

思路

在一个目录中,可能有多个不同类型的文件,我们想要抽取中其中的一部分,然后拷贝到其他的目录中或者其他主机中,这个操作在现实工作中非常常见,比如日志的迁移等。这里的要点是要在指定目录的全集中找到所有匹配的文件。分为两个操作:

1.全集的遍历

2.模式的匹配

3.在匹配之后所要进行的操作

1.全集的遍历这个思路在shell和Python中有着不同的方式(Python的方法随后讲解):

shell可以通过find命令进行遍历

2.模式匹配当然也可以使用find,它可以限定权限、文件类型、所属人、时间范围。愈多的限制所有的当然越精确。

3.通过上述的思路可以看出,我们批量拷贝相同类型文件的操作实际上是对find结果集的操作,也算是一种特殊的 “管道”,如下图所示:



案例:

在/usr 中找到所有头文件,并且把他们拷贝到/mnt/copydir目录,并且保持相同的目录结构。

shell代码如下所示:

#!/bin/bash
#这里我们只是为了解决问题,更深入的做法是应该抽象出来该类问题的共性,然后固化脚本;
#找到头文件路径列表
head_files=`find /usr -name "*.h"`
des_dir="/mnt/copydir"
file_count=0

[ -d $des_dir ] || mkdir -p $des_dir &> /dev/null

#进行拷贝过程
for file in $head_files
do
source_dir=${file%/*}
#判断目标目录是否存在,不存在创建
[ -d $des_dir$source_dir ] || mkdir -p $des_dir$source_dir
cp -upv $file $des_dir$source_dir
echo "$file has been copy."
((file_count++))
done

#对拷贝结果进行判断
if [ $? != 0 ]; then
echo "copy files error!!!"
else
echo "copy files successfully!,total $file_count files."
fi


小结:

一旦获得了结果集,我们可以对它做拷贝、删除、修改等很多操作,这个脚本还应该把源目录等信息都使用参数化传递。

关于python对目录的操作以后会进行探讨。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  shell 脚本