我想复制不同的文件夹&其中的文件(所有文件夹都相同)到另一个文件夹 - unix

时间:2015-06-15 05:32:48

标签: linux shell for-loop copy directory

假设我有多个文件夹,每个文件夹中有很多文件,但我感兴趣的文件是“xyz.p”:

〜/ home / A / xyz.p

〜/家庭/ B / xyz.p

〜/家庭/ C / xyz.p

〜/家庭/ d / xyz.p

现在我想将每个文件夹中只有一个文件从“xyz.p”复制到另一个目录:

〜/试验/ A / xyz.p

〜/ TRAIL / B / xyz.p

〜/ TRAIL / C / xyz.p

〜/ TRAIL / d / xyz.p

我不想复制文件夹A,B,C,D中的其他文件。

现在我已经尝试了很长时间使用shell脚本,但它并没有真正起作用。

2 个答案:

答案 0 :(得分:0)

我发现解决这个问题的最简单方法是编写一个简单的脚本。

#!/bin/bash

STARTDIR="home"
TARGETDIR="test"

FILENAME="xyz.p"

for DIR in 'A' 'B' 'C' 'D';
do
  cp -rfv $STARTDIR/$DIR/$FILENAME $TARGETDIR/$DIR/$FILENAME
done

此脚本从startdir / subdir获取文件并将其放入targetdir / subdir目录。

子目录可以在for命令行的单引号中放入列表中。

-rfv意味着副本将是递归的(包括所有子目录),强制和详细(告诉你它正在做什么)。

这个脚本的输出对象是

$./moveit.sh
`home/A/xyz.p' -> `test/A/xyz.p'
`home/B/xyz.p' -> `test/B/xyz.p'
`home/C/xyz.p' -> `test/C/xyz.p'
`home/D/xyz.p' -> `test/D/xyz.p'

希望这很有用。
请在尝试之前尝试做更多的研究:)

答案 1 :(得分:0)

使用GNU Parallel看起来像这样:

parallel 'mkdir -p ~/trial/{//}; cp {} ~/trial/{//}' ::: */xyz.p

GNU Parallel是一个通用的并行程序,可以很容易地在同一台机器上或在你有ssh访问权限的多台机器上并行运行作业。它通常可以替换for循环。

如果要在4个CPU上运行32个不同的作业,并行化的直接方法是在每个CPU上运行8个作业:

Simple scheduling

GNU Parallel会在完成后生成一个新进程 - 保持CPU处于活动状态,从而节省时间:

GNU Parallel scheduling

<强>安装

如果没有为您的发行版打包GNU Parallel,您可以进行个人安装,不需要root访问权限。这可以在10秒内完成:

(wget -O - pi.dk/3 || curl pi.dk/3/ || fetch -o - http://pi.dk/3) | bash

有关其他安装选项,请参阅http://git.savannah.gnu.org/cgit/parallel.git/tree/README

了解详情

查看更多示例:http://www.gnu.org/software/parallel/man.html

观看介绍视频:https://www.youtube.com/playlist?list=PL284C9FF2488BC6D1

完成教程:http://www.gnu.org/software/parallel/parallel_tutorial.html

注册电子邮件列表以获得支持:https://lists.gnu.org/mailman/listinfo/parallel