方法一: cat查询文件中的目录通过ls重定向

echo "`cd /home/hadoop/test1/data`"
echo "`ls * >b`"
cat b | grep -v "tmp"|grep -v "temp" |grep -v "cmd"> c

for i in `cat c`;do
{
if [ $? -eq 0 ];then
cp /home/hadoop/test1/data/${i} /home/hadoop/test1/data/a
fi
}
done

方法二: find查找路径下的文件进行遍历


function newdownload(){
receiveDir=/home/hadoop/test1
localDir=/home/hadoop/test2
filelastdate=`date -d -1day +"%Y%m%d"`
filenowdate=`date +"%Y%m%d"`
# 日志文件
log=/home/hadoop/test1/download_`date +'%Y%m%d'`.log
# 遍历路径中的文件,通过grep -v过滤临时文件
for file in `find ${receiveDir} | grep -v "tmp"|grep -v "temp" |grep -v "cmd"`
do
# 复制文件到另一个路径
cp $file ${localDir}
# 输出时间打印日志到log文件
echo "`date +"%Y-%m-%d %H:%M:%S"` download file ${file}">>${log}
done
}
# 执行延迟时间
while true
do
#Download
newdownload
sleep 300
done
Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐