我想要编写一个在输入目录上递归遍历的脚本,并为每个文件在一个单独的目录层次结构下生成相应的文件。
例如,文件input/a/b/c.txt变成output/a/b/c.txt,input/a/d.txt变成output/a/d.txt。当我这样做时,用输出目录的名称替换输入目录的名称是什么?
我知道的两种方式感觉不对。第一种方法是使用#参数展开来消除文件前缀。但是,如果输入目录的名称具有像*这样的特殊字符,则会发生奇怪的事情。如果输入目录的名称在变量中,也很难读懂。
find input -type f | while read -r infile; do
outfile=output/"${infile#input/}"
mkdir -p "$(dirname "$outfile")"
some-program "$infile" > "$outfile"
done我尝试过的另一件事是cd到输入目录,并对所有内容使用绝对链接。但是,这需要对cd进行多次调用,并且还依赖于readlink,这并不是最可移植的。
abspwd=$(pwd)
absinput=$(readlink -f input)
absoutput=$(readlink -f output)
cd "$absinput"
find . -type f | while read infile; do
outfile="$absoutput/$infile"
mkdir -p "$(dirname "$outfile")"
some-program "$infile" > "$outfile"
done
cd "$abspwd"还有别的办法吗?我觉得应该有一种更简单的方法来做到这一点。
发布于 2021-02-28 14:32:22
你差点就到了。
我将放置一个rsync,它只在输出中复制输入的目录结构。当您的查找管道运行时,它会将一些程序的输出抛到正确的位置。
TOP="input"
rsync -a -f'+ */' -f'- *' "$TOP"/ output/
find "$TOP" -type f | while IFS= read -r infile; do
outfile=output/${infile#"$TOP"/}
some-program "$infile" > "$outfile"
done注带有换行符的文件名将不被正确处理。如果您认为这种情况是合理的,那么可以使用更多的代码来处理它们。我不想分散您的注意力,即将文件名从一个dir迁移到另一个dir。
https://unix.stackexchange.com/questions/636774
复制相似问题