好的,我的文件夹中有很多文件包含字符串“$变量名称.txt”:
for file in find output/ -name "*$varname*.txt" -type f; do echo $file; done
...
现在这些文件都有两行和九列。我想将第 2 行、第 9 列的内容添加到文件名的末尾(就在 之前.txt
)。
所以我知道如何打印所有这些文件的单元格(2,9)中的值:
find output/ -name "*$varname*.txt" -type f -exec awk -F' ' 'NR==2{print $9}' {} \;
我所苦苦挣扎的是如何将该字符串作为文件名扩展名之前的最后一个字符串
答案1
您需要捕获该值并用它构造新的文件名。
find output/ -name "*$varname*.txt" -type f -exec sh -c '
for file; do
value=$(awk "NR==2 {print \$9; exit}" "$file")
echo mv "$file" "${file%.*}$value.${file##*.}"
done
' sh {} +
我在指令中调用一个 shell 脚本-exec
,并向其传递几个文件名(使用-exec ... +
而不是-exec ... \;
)
尾随的“sh”变为 $0,文件名变为 $1、$2 等
答案2
这是一个GNUparallel
方法:
find output/ -name "*$varname*.txt" -type f -print0 |
parallel -0 'echo mv {} {.}$(awk -F" " "NR==2{print\$9}" {}).{=s/.*\.//=}'
这将把零分隔文件列表通过管道传送到parallel
列出重命名命令的文件中 –echo
如果命令正确则删除。parallel
带有方便的替换字符串,{}
由(当前处理的)输入文件名替换,{.}
由不带扩展名的输入文件名替换,{=perl expression=}
您可以运行任何perl
可以执行的操作,例如此处的替换。awk
只需使用以下命令添加命令的输出命令替换。