我试图从某个目录的所有文件中删除特定单词的列表,然后将其替换为任何内容。
So:
这个很棒的内容 720p BLAH FOO BANG OOO - 30.9.2013.mp4
Becomes:
这个很棒的内容 - 30.9.2013.mp4
现在,以下内容非常适合单个查找和替换一个单词。
find path/to/folder/ -maxdepth 3 -name '*.*' -execdir bash -c 'mv -i "$1" "${1//foo/}"' bash {} \;
我也尝试了多个发现,但这似乎是一个很长的方法,而且我似乎以这种方式遇到了问题。
我有几个问题:
- 希望它不区分大小写
- 需要“${1//foo/}”来引用列表
- 如果大于 1,则删除空格
尝试将其作为 bash 脚本在 cronjob 上运行。
除非有更好的方法来删除“This Awesome Content”-“30.9.2013.mp4”之间的所有内容。
非常感激。
您可以使用“echo”命令将文件名作为变量进行访问。完成后,进行所需更改的最强大方法是使用“sed”。您可以使用“-e”标志将 sed 命令串在一起。作为 bash 中 for 循环的一部分,这一行为您提供了一个开始。您还可以使用这样的行作为“find”语句的一部分。
echo $fyle | sed -e 's/FOO//gI' -e 's/BANG//gI'
获得所需的文件名后,您可以将它们移回原始名称。如果您需要更具体的说明,请告诉我。
UPDATE:这是一个更完整的解决方案。您必须将脚本调整为您自己的文件名等。
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'
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)