信息发布→ 登录 注册 退出

如何在Linux中批量重命名 Linux rename通配符使用技巧

发布时间:2025-08-29

点击量:
rename命令结合正则表达式可高效批量重命名文件,其核心是s/旧模式/新模式/g语法,支持捕获组与复杂匹配,但使用时需谨慎。

在Linux中批量重命名文件,最强大也最灵活的工具无疑是

rename
命令,尤其当它结合了强大的正则表达式(regex)和shell通配符时。它不是简单地替换字符串,更像是在用一套精密的规则去“雕刻”文件名,让批量操作变得既高效又精准。

rename
命令的核心在于其利用Perl兼容正则表达式(PCRE)进行模式匹配和替换的能力。它的基本语法通常是这样的:

rename 's/旧模式/新模式/g' 文件...

这里的

s
代表“substitute”(替换),
/旧模式/
是你想要匹配的文件名部分,
/新模式/
是你想要替换成的内容。最后的
g
(可选)表示全局替换,即一行中所有匹配项都替换,而不是只替换第一个。

举个最直接的例子:如果你有一堆文件名都带“old”前缀的图片,想把它们全部改成“new”:

# 假设有 old_pic1.jpg, old_pic2.jpg 等
rename 's/old_/new_/' *.jpg
# 结果会变成 new_pic1.jpg, new_pic2.jpg

这看起来简单,但真正的魔力在于“旧模式”和“新模式”中可以使用的正则表达式。

理解
rename
命令的正则表达式基础:从简单替换到复杂匹配

说实话,刚接触

rename
的时候,我个人觉得最让人头疼的不是命令本身,而是它背后那套正则表达式的逻辑。但一旦你掌握了,它就像打开了一个新世界的大门。
s/旧模式/新模式/
这个结构,你可以把它想象成在对每个文件名进行一次文本编辑操作。

最基础的匹配符包括:

  • .
    :匹配任意单个字符(除了换行符)。
  • *
    :匹配前一个字符零次或多次。
  • +
    :匹配前一个字符一次或多次。
  • ?
    :匹配前一个字符零次或一次。
  • ^
    :匹配字符串的开头(文件名的开头)。
  • $
    :匹配字符串的结尾(文件名的结尾)。
  • []
    :匹配方括号内列出的任意一个字符。例如
    [abc]
    匹配a、b或c。
  • \d
    :匹配任意数字(等同于
    [0-9]
    )。
  • \w
    :匹配任意字母、数字或下划线(等同于
    [a-zA-Z0-9_]
    )。

我们来看几个实际应用:

  1. 批量修改文件扩展名: 假设你有一堆

    .txt
    文件,想全部改成
    .md

    rename 's/\.txt$/.md/' *.txt
    # 注意,这里的点号`\.`需要转义,因为它在regex中有特殊含义。
    # `$`确保我们只匹配文件扩展名,而不是文件名中间的`.txt`。
  2. 给文件添加前缀或后缀: 想给所有

    .jpg
    图片加上“photo_”前缀。

    rename 's/^/photo_/' *.jpg
    # `^`匹配文件名的开头。

    或者加上日期后缀(这通常需要结合shell变量,但如果日期是文件名的一部分,就可以用regex)。

  3. 移除文件名中的特定字符或模式: 文件名里有很多空格或特殊字符,想把它们替换成下划线。

    rename 's/ /_/g' *.mp4 # 把所有空格替换成下划线
    rename 's/[()]//g' * # 移除文件名中的括号

    这里的

    g
    很重要,它确保了所有匹配的空格都会被替换,而不仅仅是第一个。

这些例子展示了正则表达式在

rename
中的基本威力,它远比简单的查找替换要强大得多。

处理复杂命名场景:利用捕获组与编号进行精细化重命名

当简单的替换无法满足需求时,

rename
的捕获组(Capturing Groups)就成了你的得力助手。捕获组允许你“记住”正则表达式匹配到的特定部分,并在替换字符串中通过编号(
$1
,
$2
等)来引用它们。这简直是精细化重命名的利器。

想象一下这个场景:你有一些电影文件,命名格式是

电影名_年份_分辨率.mp4
,比如
Avengers_2019_1080p.mp4
。现在你想把格式调整为
年份-电影名-分辨率.mp4
,即
2019-Avengers-1080p.mp4

这里捕获组就派上用场了:

# --dry-run 是个好习惯,先看看会发生什么
rename --dry-run 's/^([^_]+)_(\d{4})_(\d+p)\.mp4$/$2-$1-$3.mp4/' *.mp4
# 解释一下:
# `^([^_]+)`:捕获第一个下划线前的所有字符(电影名),存入$1。
# `_(\d{4})`:捕获下划线后的四个数字(年份),存入$2。
# `_(\d+p)`:捕获下划线后的数字和p(分辨率),存入$3。
# `\.mp4$`:匹配文件扩展名。
# 替换部分`$2-$1-$3.mp4`:按照我们想要的顺序重新组合。

如果

--dry-run
的结果符合预期,去掉它再执行。

另一个常见的需求是调整文件中的数字序列。比如,你有一批文件是

part1_episode.mp4
,
part2_episode.mp4
,你想把
partX
移到后面。

rename 's/^(part)(\d+)_(episode\.mp4)$/$2_$1$3/' *.mp4
# 这里$1是"part",$2是数字,`$3`是"episode.mp4"。
# 结果会是 `2_part_episode.mp4`

当然,这只是一个例子,实际应用中你可能会遇到更复杂的编号模式,但核心思想都是通过括号来捕获,再通过

$N
来引用。这种能力让
rename
在处理大量结构化但需要调整顺序的文件名时,效率极高。

我个人在整理照片和视频素材时,经常会用到捕获组来统一命名格式,比如从

IMG_YYYYMMDD_HHMMSS.jpg
中提取日期和时间,然后重新组合成
YYYY-MM-DD_HH-MM-SS_IMG.jpg
。这虽然需要一些正则表达式的练习,但绝对物有所值。

rename
命令的潜在陷阱与安全实践:避免数据丢失的技巧

rename
虽好用,但它毕竟是对文件系统进行操作,一个不小心就可能酿成大错。我见过不少人因为正则表达式写错或者忘了预览,导致文件名乱七

标签:# 下划线  # 你想要  # 文件扩展名  # 替换成  # 重命名  # 第一个  # 想把  # 新模式  # 你有  # linux  # Regex  #   # 字符串  # perl  # yy  # 数据丢失  # 工具  # 正则表达式  
在线客服
服务热线

服务热线

4008888355

微信咨询
二维码
返回顶部
×二维码

截屏,微信识别二维码

打开微信

微信号已复制,请打开微信添加咨询详情!