此代码背后的想法是查找大于1KB(或1000字节)的目录中的所有文件,压缩它们,并从原始目录中删除它们.我能够找出两个单独的命令,但不确定如何链接第一个命令到第二个命令的输出(如果这是有道理的)?谁能指出我正确的方向?
# Initialize variables
dir=~/Test
# Change directory to $DIRECTORY
cd "$dir"
# Find all files in the current directory that are larger than 1000 bytes (1KB).
find . -maxdepth 1 -type f -size +1000c | zip -mT backup
解决方法:
我之前提供了一个存根,但我决定充实脚本.这仍然不会处理病毒情况,例如包含通配符的文件名.
#!/usr/bin/bash
# the following line handles filenames with spaces
IFS='
'
backupfilename=backup;
for file in $(find . -maxdepth 1 -type f -size +1000c)
do
if zip ${backupfilename} -u "${file}" # test that zip succeeded
then
echo "added file ${file} to zip archive ${backupfilename}" 1>&2;
# add your remove command here; remember to use quotes "${filename}"
echo "file ${file} has been deleted" 1>&2;
fi
done
我唯一遗漏的是删除命令.您应该自己动手并仔细测试,以确保不会意外删除您不想删除的文件.
标签:bash,linux,shell,scripting 来源: https://codeday.me/bug/20190823/1701426.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。