gpt4 book ai didi

linux - 如何让 echo 只打印已删除的文件路径?

转载 作者:塔克拉玛干 更新时间:2023-11-03 00:06:10 24 4
gpt4 key购买 nike

我正在尝试编写一个脚本来每天在一个目录中创建 mysqldumps,并检查该目录中的所有备份并删除将在 cron 上运行的超过 7 天的备份。

所以我的功能正常工作,只是我最后一个 echo 命令没有按照我的意愿执行。这是我目前所拥有的:

DBNAME=database
DATE=`date +\%Y-\%m-\%d_\%H\%M`
SQLFILE=$DBNAME-${DATE}.sql
curr_dir=$1

#MAIN
mysqldump -u root -ppassword --databases $DBNAME > $SQLFILE

echo "$SQLFILE has been successfully created."

#Remove files older than 7 days

for filepath in "$curr_dir"*
do
find "$filepath" -mtime +7 -type f -delete
echo "$filepath has been deleted."
done
exit

因此备份创建和旧文件的删除都有效。但是,我的问题是 echo "$filepath has been deleted." 正在打印目录中的所有文件,而不仅仅是 7 天前被删除的文件。我哪里出错了?

编辑(完整解决方案):

这是一个完整的解决方案,它使用了每个人从答案和评论中得到的建议,最终为我工作。这适用于 cron 作业。我必须指定主函数的输出文件路径,因为文件是在根目录而不是参数 $1 中指定的路径中创建的。

谢谢大家的帮助! if 语句还检查 $1 是否是我要删除文件的指定目录。

#Variables
DBNAME=database
DATE=`date +\%Y-\%m-\%d_\%H\%M`
SQLFILE=$DBNAME-${DATE}.sql
curr_dir=$1

#MAIN
mysqldump -u root -ppassword --databases $DBNAME > /path/to/db-backups/directory/$SQLFILE

echo "$SQLFILE has been successfully created."

#Remove files older than 7 days

for filepath in "$curr_dir"*
do
if [[ $1 = "/path/to/db-backups/directory" ]]; then
find "$filepath" -mtime +7 -type f -delete -exec sh -c 'printf "%s has been deleted.\n" "$@"' _ {} +
fi
done
exit

最佳答案

您可以将 echo 合并到 find 中:

find "$filepath" -mtime +7 -type f -delete -exec echo '{}' "has been deleted." \;

-delete 选项只是 -exec rm '{}'\; 的快捷方式,所有 -exec 命令都会运行按照您指定的顺序。

关于linux - 如何让 echo 只打印已删除的文件路径?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46309048/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com