批量重命名文件的核心是使用rename命令或for循环结合mv命令。1. 替换扩展名:可用rename 's/\.txt$/.md/' *.txt或for file in *.txt; do mv "$file" "${file%.txt}.md"; done实现。2. 添加前缀/后缀:如rename 's/^/old_/' *.jpg添加前缀,rename 's/$/.bak/' *.txt添加后缀。3. 替换特定字符串:rename 's/draft/final/g' *draft*.doc将draft替换为final。4. 删除多余字符:rename 's/\s+/_/g' *将空格换为下划线,rename 's/\s+(copy)//' *删除(copy)部分。5. 批量编号:i=1; for file in *.jpg; do mv "$file" "$(printf "image_%03d.jpg" "$i")"; i=$((i+1)); done实现零填充编号。选择rename适用于正则替换,简洁高效;for循环加mv则更灵活,适合复杂逻辑。为避免错误,应先空运行(rename -n或echo mv)、备份文件、测试正则、处理特殊字符并从小范围开始测试。高级技巧包括:结合find递归重命名,如`find . -name "*.

在Linux命令行下批量重命名文件,这事儿说起来简单,但真要玩转,其实挺有意思的,也确实是日常操作中一个效率提升的利器。核心思路无非两种:一种是利用强大的
rename
for
mv
批量重命名文件的具体操作,其实有很多种玩法,下面我列举一些最常见的,也是我个人觉得最实用的场景:
1. 替换文件扩展名
这是最基础的需求之一。比如,你有一堆
.txt
.md
使用
rename
rename 's/\.txt$/.md/' *.txt
这里
s/old/new/
\.txt$
.txt
\
.
$
使用
for
mv
for file in *.txt; do
mv "$file" "${file%.txt}.md"
done"${file%.txt}"file
.txt
2. 添加前缀或后缀
假设你想给所有图片文件加上
old_
_backup
添加前缀:
# 使用 rename
rename 's/^/old_/' *.jpg
# 使用 for 循环
for file in *.jpg; do
mv "$file" "old_$file"
dones/^/old_/'
^
添加后缀:
# 使用 rename
rename 's/$/.bak/' *.txt
# 使用 for 循环
for file in *.txt; do
mv "$file" "${file%.txt}.bak" # 如果想替换掉原有扩展名
# 或者 mv "$file" "${file}_bak.txt" # 如果想在扩展名前添加后缀
dones/$/_backup/'
$
3. 替换文件名中的特定字符串
比如,你有一批文件名中都含有
draft
final
# 使用 rename
rename 's/draft/final/g' *draft*.doc
# 使用 for 循环
for file in *draft*.doc; do
new_name=$(echo "$file" | sed 's/draft/final/g')
mv "$file" "$new_name"
dones/draft/final/g
g
sed
4. 删除文件名中的特定部分
有时候文件名里有一些多余的字符,比如下载时带的网站名或者日期戳。
# 删除文件名中所有的空格,替换成下划线
rename 's/\s+/_/g' *
# 删除文件名中形如 "(copy)" 的部分
rename 's/\s+\(copy\)//' *
# 使用 for 循环删除文件名中的特定字符串
for file in *; do
new_name=$(echo "$file" | sed 's/\[www.example.com\]//g')
mv "$file" "$new_name"
done\s+
5. 文件批量编号
这在我处理照片或文档时特别有用,能让文件排序更规整。
# 使用 for 循环进行编号,并补齐零(例如 001, 002)
i=1;
for file in *.jpg; do
mv "$file" "$(printf "image_%03d.jpg" "$i")"
i=$((i+1))
doneprintf "%03d"
rename
mv
说实话,我个人在处理批量重命名时,大部分时间会倾向于使用
rename
rename 's/[^a-zA-Z0-9_.-]/_/g' *
然而,
for
mv
for
for
所以,我的建议是:
rename
for
mv
for
批量重命名这事儿,虽然能大大提高效率,但一旦操作失误,那后果可能就是灾难性的——文件丢失、文件名混乱,甚至导致程序无法识别文件。我遇到过几次因为粗心大意而“手抖”的情况,那感觉可真不好受。所以,有几个原则我每次都会牢记:
首先,务必进行“空运行”(Dry Run)。这是最最重要的一步!
rename
-n
--no-act
rename -n 's/\.txt$/.md/' *.txt
对于
for
mv
echo
mv
for file in *.txt; do
echo mv "$file" "${file%.txt}.md"
done通过空运行,你可以提前看到所有将要发生的改变,确保它们符合你的预期。
其次,备份,备份,还是备份! 尤其是对于那些非常重要、不可再生的文件,在进行任何批量操作之前,花几分钟时间复制一份到其他地方,或者直接打包成一个
.zip
.tar.gz
再者,彻底理解你的正则表达式。如果你选择了
rename
另外,从小范围开始测试。如果目标文件很多,先找几个代表性的文件,或者复制一小部分文件到一个测试目录中,进行实际的重命名操作。确认无误后再应用到整个数据集。
最后,注意文件名中的特殊字符和空格。在Bash脚本中,包含空格的文件名必须用引号
""
mv "$file" "new name.txt"
mv $file new name.txt
for
"$file"
当你的重命名需求变得有点“花哨”时,仅仅替换字符串可能就不够了,这时候就需要请出正则表达式和通配符的组合拳了。这就像给你的命令行操作赋予了更强的逻辑判断能力。
1. 递归重命名:结合find
如果你需要重命名子目录中的文件,
find
.bak
find . -name "*.bak" -exec rename 's/\.bak$//' {} \;这里
find . -name "*.bak"
.bak
-exec
rename
{}\;
+
\;
xargs
2. 利用捕获组进行文件名重组
正则表达式的捕获组(用括号
()
比如,你有一批文件名为
YYYY-MM-DD_title.txt
title_YYYYMMDD.txt
rename 's/^(\d{4}-\d{2}-\d{2})_(.*)\.txt$/$2_$1.txt/' *.txt这里:
^(\d{4}-\d{2}-\d{2})2023-10-26
$1
_(.*)
.txt
$2
\.txt$
$2_$1.txt
这种方式极其强大,可以让你根据文件名的不同部分进行灵活的重组。
3. 添加带填充的序列号(结合printf
前面提过简单的编号,如果你的文件数量很多,或者你想在文件名中插入一个特定格式的序列号,
printf
假设你想给所有
image_
i=101;
for file in image_*.jpg; do
# 提取原始扩展名
extension="${file##*.}"
# 构造新文件名,带三位零填充
new_name=$(printf "photo_%03d.%s" "$i" "$extension")
mv "$file" "$new_name"
i=$((i+1))
done"${file##*.}"通过这些高级技巧,你会发现Linux命令行下的文件操作远比你想象的要强大和灵活。关键在于多练习,多尝试,逐步掌握正则表达式的精髓,它会让你在命令行世界里如鱼得水。
以上就是Linux命令行批量重命名文件技巧的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号