有没有类似的命令
mv --preserve-structure src src/1 src/2/3 dst
这创造了dst/1
和dst/2/3
?它的工作方式应该与 类似mv src/* dst
,但仅移动列出的子树。
答案1
> tar -cf - src/1 src/2/3 | (mkdir dst; cd dst; tar -xv --strip-components=1 -f -)
答案2
假设 bash 和 GNU find。
mv_preserve_structure() {
local src_file="$1"
local dest="$2"
local rel_dir="$(dirname "$src_file")/"
rel_dir="${rel_dir#*/}" # returns "2/3" if rel_dir was "src/2/3"
mkdir -p "$dest/$rel_dir"
mv "$src_file" "$dest/$rel_dir"
}
# unlike mv, this requires the destination dir as the first parameter
mv_dirs() {
local dest="$1"
shift
for dir in "$@"; do
for filename in "$dir"/*; do
[[ -f "$filename" ]] && mv_preserve_structure "$filename" "$dest"
done
done
}
mv_dirs dst src src/1 src/2/3
答案3
在 Linux 下,rename
从 Linux 实用程序中使用(rename.ul
在 Debian 和 Ubuntu 下):
rename src dst src/1 src/2/3 # dst/2 must exist
使用rename
Debian 和 Ubuntu 安装的 Perl 脚本prename
或rename
:
rename 's!^src!dst!' src/1 src/2/3 # dst/2 must exist
rename 'use File::Basename; use File::Path;
s!^src!dst! && mkpath(dirname($_))' src/1 src/2/3
这是一个 shell 函数,除了参数顺序之外,它可以执行您所要求的操作:
mv-preserving-structure () {
s=${1%/} t=${2%/}; shift 2
for x; do
case $x in
$s/*)
y=$t${x#$s}
mkdir -p -- "${y%/*}"
mv -- "$x" "$t${x#$s}";;
esac
done
}
mv-preserving-structure src dst src/1 src/2/3