我需要一种循环遍历大目录 (/home/data/playerdata/) 中子目录的方法,以便获取特定文件,同时保留我尝试获取的特定文件的父文件夹名称。
我基本上需要这个来从备份中恢复一个特定的文件。
示例:
要循环的主目录 = /home/minecraft/survival1/plugins/Survival/playerdata/
我要恢复的特定文件的路径 = /home/minecraft/survival1/plugins/Survival/playerdata/004fc15d-294c-4a42-a1af-1206c148e39b/economy.yml
脚本循环执行的示例命令 = cp/home/minecraft/survival1/plugins/Survival/playerdata/004fc15d-294c-4a42-a1af-1206c148e39b/economy.yml/restored/playerdata/004fc15d- 294c-4a42-a1af-1206c148e39b/economy.yml
我需要一个脚本来遍历“playerdata”目录中的每个文件夹(UUID 位)并复制该特定文件,同时保留其 UUID 父文件夹。
这是我到目前为止尝试过的:
for FILE in $BASEDIR
cp $BASEDIR/FILE/economy.yml /home/restored/FILE/economy.yml
这是在 Debian 服务器上运行
最佳答案
我建议为此使用 find:
cd /home/minecraft/survival1/plugins/Survival/playerdata/
find -name "economy.yml" -exec cp --parents {} /home/minecraft/restore/ \;
--parents
复制时保存目录结构。
或者像您尝试的那样使用 for 循环:
find . -type f -print0 | while IFS= read -r -d '' filename;
do
mkdir --parents "$RESTOREDIR/$player"
cp "$BASEDIR/$player/economy.yml" "$RESTOREDIR/$player/economy.yml"
done
关于linux - 从具有父目录的每个子文件夹复制特定文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55222593/