思路
在一个目录中,可能有多个不同类型的文件,我们想要抽取中其中的一部分,然后拷贝到其他的目录中或者其他主机中,这个操作在现实工作中非常常见,比如日志的迁移等。这里的要点是要在指定目录的全集中找到所有匹配的文件。分为两个操作:
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
小结:
一旦获得了结果集,我们可以对它做拷贝、删除、修改等很多操作,这个脚本还应该把源目录等信息都使用参数化传递。
本文永久更新地址://m.ajphoenix.com/linux/21763.html