2024年11月Linux rename命令文件重命名的用法汇总(2)

发布时间:

  ⑴网上流程的两个去空格的版本:

  ⑵find 。 -type f -name “* *” -print |

  ⑶while read name; do

  ⑷na=$(echo $name | tr ‘ ’ ‘_’

  ⑸if [[ $name != $na ]]; then

  ⑹mv “$name” $na

  ⑺这个版本以前我一直用的,不知道哪个网上搜刮来的,当时还没有系统的学习过 tr/sed/awk命令。

  ⑻注解一下,很好理解, find 。 type f -name “* *” -print 这一句是查找当前目录下所有类型为普通文件的 并且名字之中含有空格的文件,并打印出来,其实 find默认就是打印的 这个 -print 多余了,然后 通过管道传输给 while 循环读取,文件名放到 name 变量里,用 tr 命令 替换空格为 下划线。 下面判断如果执行后的名称不相同,使用 mv 命令重命名。但这个if判断可有可无,因为find已经查询了所有文件名中含有空格的,那么经过 tr 命令后, $na变量肯定不等于 $name 变量的。

  ⑼所以这段代码可以简化:

  ⑽find 。 -type f -name “* *” |

  ⑾while read name; do

  ⑿na=$(echo $name | tr ‘ ’ ‘_’

  ⒀mv “$name” “$na”

  ⒁tr 可以看着是 sed 的一个精简版本,tr 用下划线来替换空格。

  ⒂还有一个 是 sed 版本实现:

  ⒃for f in *;do mv “$f” `echo “$f” | sed ‘s/[ ]+/_/g’ `; done

  ⒄这里的 sed表达式还可以这样写:

  ⒅sed ‘s/[[:space:]]+/_/g’

  ⒆不过记住,sed里的出现一次或多次的加号是需要添加反斜杠的。即:+

  ⒇好了,这两种办法都太***罗嗦了,看看rename实现吧:

  ⒈rename ‘s/[ ]+/_/g’ *

  ⒉OK就这么简单。

  ⒊方括号内的空格可以用 [:space:]代替,

  ⒋即可以写成 ‘s/[[:space:]]+/_/g’

  ⒌这里注意,rename 采用的是标准perl正则语法,所以无须将 加号转变为反斜杠加号 。即 + 不能修改为 +,否则替换失败。

  ⒍还有几个好玩的例子:

  ⒎比如统一在文件头部添加上 hello

  ⒏rename ‘s/^/hello/’ *

  ⒐统一把.html扩展名修改为 .htm

  ⒑rename ‘s/.html$/.htm/’ *

  ⒒统一在尾部追加 .zip后缀:

  ⒓rename ‘s/$/.zip/’ *

  ⒔统一去掉.zip后缀:

  ⒕rename ‘s/.zip$//’ *

  ⒖规则化数字编号名,比如 .jpg, .jpg …。。 .jpg , 现在要使文件名全部三位即 .jpg …。 .jpg

  ⒗rename ‘s/^//’ [-].jpg

  ⒘# 这一步把 .jpg 。。。。。 .jpg 变幻为 .jpg 。。。。 .jpg

  ⒙rename ‘s/^//’ [-][-].jpg

  ⒚# 这一步把 .jpg 。。。。。 .jpg 变幻为 .jpg 。。。。。 .jpg

  ⒛Ok ,rename就研究了这么多,暂时不知道如何在rename中引入动态变量,比如 $i++

  ①我测试过 i=; rename -n “s/^.*$/$((++i/” * 执行后i被自增了,并非想我想像中那样,可以在每操作一个文件自增一,猜想可能是因为rename批量实现的,导致++i只计算一次!

  ②-n 用来测试rename过程,并不直接运行,可以查看测试效果后,然后再运行。

  ③上面就是Linux下rename命令的用法介绍了,rename命令有两个版本,目前大部分使用的是Perl版本,你在使用该命令的时候要先检查下你使用的是哪个版本,以免出现错误。