⑴网上流程的两个去空格的版本:
⑵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版本,你在使用该命令的时候要先检查下你使用的是哪个版本,以免出现错误。