我正在尝试从我的所有文件中的某个目录中删除特定单词的列表,并将它们替换为任何内容。
所以:
This Awesome Content 720p BLAH FOO BANG OOO - 30.9.2013.mp4
变成:
This Awesome Content - 30.9.2013.mp4
现在以下内容非常适合单个查找和替换一个单词。
find path/to/folder/ -maxdepth 3 -name '*.*' -execdir bash -c 'mv -i "$1" "${1//foo/}"' bash {} \;
我也尝试了多个发现,但这似乎是一个很长的路要走,而且我似乎以这种方式遇到了问题。
我有几个问题:
- 希望它不区分大小写
- 需要“${1//foo/}”来引用列表
- 如果大于 1,则删除空格
尝试在 cronjob 上将其作为 bash 脚本运行。
除非有更好的方法来删除“This Awesome Content”-“30.9.2013.mp4”之间的所有内容。
非常感谢。
最佳答案
您可以使用“echo”命令将文件名作为变量访问。完成后,进行所需更改的最有效方法是使用“sed”。您可以使用“-e”标志将 sed 命令串在一起。作为 bash 中 for 循环的一部分,这一行为您提供了一个开始。您也可以使用这样的一行作为“查找”语句的一部分。
echo $fyle | sed -e 's/FOO//gI' -e 's/BANG//gI'
一旦您有了所需的文件名,您就可以将它们移回原来的名称。如果您需要更具体的说明,请告诉我。
更新:这是一个更完整的解决方案。您必须将脚本调整为您自己的文件名等。
for fyle in $(find . -name "*.*")
do
mv -i $fyle `echo $fyle | sed -e 's/FOO//gI' -e 's/BANG//gI' `
done
最后,要用一个空白字符替换多个空白字符,您可以添加另一个 sed 命令。这是一个工作命令:
echo "file input.txt" | sed 's/ */ /g'
关于linux - 从文件名中删除单词列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19095514/