正则表达式重命名所有文件递归删除字符“?”后的所有内容命令行

时间:2013-06-07 20:56:29

标签: regex linux bash command-line

我有一系列文件,我想使用* nix系统上提供的命令行工具进行清理。现有文件的名称如此。

filecopy2.txt?filename=3
filecopy4.txt?filename=33
filecopy6.txt?filename=198
filecopy8.txt?filename=188
filecopy3.txt?filename=19
filecopy5.txt?filename=1
filecopy7.txt?filename=5555

我希望将它们重命名为删除“?”之后的所有字符。

filecopy2.txt
filecopy4.txt
filecopy6.txt
filecopy8.txt
filecopy3.txt
filecopy5.txt
filecopy7.txt

我相信下面的正则表达式会抓住我想从名称中删除的位,

\?(.*)

我无法弄清楚除此之外如何完成这项任务。

5 个答案:

答案 0 :(得分:3)

如果所有文件都在同一目录中(忽略.dotfiles):

$ rename -n 's/\?filename=\d+$//' -- *

如果要在目录层次结构中递归重命名文件:

$ find . -type f -exec rename -n 's/\?filename=\d+$//' {} +

删除-n选项,进行重命名。

答案 1 :(得分:2)

find . -depth -name '*[?]*' -exec sh -c 'for i do
  mv "$i" "${i%[?]*}"; done' sh {} +

使用zsh

autoload zmv
zmv '(**/)(*)\?*'  '$1$2'

将其更改为:

zmv -Q '(**/)(*)\?*(D)' '$1$2'

如果你想重命名点文件。

请注意,如果文件名可能包含多个?字符,则两者都只会从最右边的字符进行修剪。

答案 2 :(得分:2)

bash命令:

for file in *; do
  mv $file ${file%%\?filename=*}
done

答案 3 :(得分:0)

在这种情况下,您可以使用 cut 命令:

echo 'filecopy2.txt?filename=3' | cut -d? -f1

示例:

find . -type f -name "*\?*" -exec sh -c 'mv $1 $(echo $1 | cut -d\? -f1)' mv {}  \;

如果你有,可以使用重命名

rename 's/\?.*$//' *

答案 4 :(得分:0)

我在下载了一堆文件后使用了这个文件,其中包含参数的URL和参数最终都在文件名中。

这是一个Bash脚本。

for file in *; do
  mv $file ${file%%\?*};
done