最近遇到一个问题,查询文件时,发现多个目录有同样的文件,节省资源保留一个文件
原理:
1、先查找是否有多个
2、查询保留哪个路径下的文件
3、循环删除多于的文件
#!/bin/bash
#查询的文件需要自己修改
file_name="chao.txt"
#查询文件的路径需要自己修改
file_dir="/root/123"
#保留文件及路径需要自己修改
save_dir="${file_dir}/a"
save_file_dir="${save_dir}/${file_name}"
#文件个数
file_num=`find . -name ${file_name}| wc -l`
#判断文件是否为多个
if [ ${file_num} -ne 1 ];then
#查询文件路径输入到文件里面
find ${file_dir} -name ${file_name} > file_list.txt
#把保留的文件路径,在文件删除,这样就可以删除全部搜索的文件,保留指定文件
sed -i "s#${save_file_dir}# #" file_list.txt
#循环删除文件
file_names=`cat file_list.txt`
for i in ${file_names}
do
echo -e "delete $i" > delete.txt
rm -rf $i
done
else
echo -e "delete file ${save_file_dir} noley"
fi