Ubuntu中rename命令和批量重命名
原文链接:http://www.linuxidc.com/Linux/2016-11/137041.htm直接在终端中输入rename+[Enter]可以看到该命令的格式:早期版本的rename是C语言版本,如今新的Ubuntu中采用的都是perl版本,功能更加强大Usage:rename [-v] [-n] [-f] perlexpr [filenames]-v(verbo
原文链接:http://www.linuxidc.com/Linux/2016-11/137041.htm
直接在终端中输入rename+[Enter]可以看到该命令的格式:
早期版本的rename是C语言版本,如今新的Ubuntu中采用的都是perl版本,功能更加强大
Usage:rename [-v] [-n] [-f] perlexpr [filenames]
-v(verbose)打印被成功重命名的文件
-n(no-act)只显示将被重命名的文件,而非实际进行重命名操作
-f(force)覆盖已经存在的文件
perlexprPerl语言格式的正则表达式
files需要被替换的文件(比如*.c、*.h),如果没给出文件名,将从标准输入读
常用的参数是-n
,可以先用-n参数对一部小部分图片进行测试,每次执行命令会在terminal中把效果列出来,等确保没问题后去掉-n
参数,再对全部数据进行统一处理。
此次应用是为了批量重命名一批图片文件(自己的图片数据,作为caffe训练和测试数据使用)
本来全部都是这种格式:
(1).jpg
(2).jpg
…..
要改为:
test_001.jpg
test_002.jpg
……
用了比较笨的办法:先把括号去掉,再统一改格式(假定图片文件存放在terminal打开的当前目录位置)
1、去掉括号
rename -n 's/[()]//g' *.jpg
解释:
-n直接打印结果在终端中而非实际执行
引号中是perl的正则表达式,用来匹配和替换,s代表substitution,替换的意思
[()]代表匹配[]中的内容
//两个斜杠之间是空代表替换为空的内容,相当于删除
g代表全部匹配,不加g的话默认只会匹配一个括号
此处的效果类似,是将文件名中的下划线以及数字3,看图中效果应该就明白了:
2、继续重命名为想要的格式
rename -n 's/^/test_/' *.jpg
解释:
s-替换
^-在文件名称开头加字符
test_-将名称前面添加上test_
效果如下:
更详细的rename命令参考:Ubuntu用rename命令批量重命名文件
偶尔会遇到需要重命名批量文件,最典型的例子就是数码相机的相片,在Ubuntu可以用工具Purrr或者PerfixSuffix实现该功能,但重命名批量文件并不常用,为了偶尔的一次操作,安装工具(可能通过Ubuntu Software Center或者sudo apt-get install安装),加之图形化界面操作也比较费时间。事实上,rename命令就可以出色完成该工作。
- RENAME(1) Perl Programmers Reference Guide RENAME(1)
- rename [ -v ] [ -n ] [ -f ] perlexpr [ files ]
-v(verbose)打印被成功重命名的文件-n(no-act)只是显示将被重命名的文件,而不重命名(重命名之前可以用-n确认需要重命名的文件)-f(force)覆盖已经存在的文件perlexprPerl语言格式的正则表达式files需要被替换的文件(比如*.c、*.h),如果没给出文件名,将从标准输入读
- rename -n 's/Sam3/Stm32/' *.nc /*确认需要重命名的文件*/
- rename -v 's/Sam3/Stm32/' *.nc /*执行修改,并列出已重命名的文件*/
博文[3]给出了8种模式,rename命令常用到替换和转化两种(用匹配也没意义)。转换跟替换不同,替换是将replacement整个字符串替换pattern字符串,而转换则是用replacement逐个字符替换pattern逐个字符,结果依赖于replacement与pattern字符个数(见下述分析)。匹配:m// (可以省略m,直接写成/regexp/)替换:s///转化:tr///
- s/PATTERN/REPLACEMENT/egimosx
e Evaluate the right side as an expression.g Match globally, i.e. all occurrences.i Case-insensitive pattern matching.m Treat string as multiple lines.o Only compile pattern once, even if variables within it change.s Treat string as single line.x Use extended regular expressions
- tr/SEARCHLIST/REPLACEMENTLIST/cds
- y/SEARCHLIST/REPLACEMENTLIST/cds
c Complement the SEARCHLIST.d Delete found but unreplaced characters.s Squash duplicate replaced characters.
- jelline@jelline:~$ rename -n 'tr/Sam3/Stm/' FastSpiSam3C.nc /*替换字符短,用最后一个字符m替换3*/
- FastSpiSam3C.nc renamed as FtstSpiStmmC.nc
- jelline@jelline:~$ rename -n 'tr/Sam3/Stm32/' FastSpiSam3C.nc /*替换字符长,多出字符被忽略*/
- FastSpiSam3C.nc renamed as FtstSpiStm3C.nc
x? 匹配 0 次或一次 x 字符串x* 匹配 0 次或多次 x 字符串,但匹配可能的最少次数x+ 匹配 1 次或多次 x 字符串,但匹配可能的最少次数.* 匹配 0 次或一次的任何字符.+ 匹配 1 次或多次的任何字符{m} 匹配刚好是 m 个 的指定字符串{m,n}匹配在 m个 以上 n个 以下 的指定字符串{m,} 匹配 m个 以上 的指定字符串[] 匹配符合 [] 内的字符[^] 匹配不符合 [] 内的字符[0-9]匹配所有数字字符[a-z]匹配所有小写字母字符[^0-9]匹配所有非数字字符[^a-z]匹配所有非小写字母字符^ 匹配字符开头的字符$ 匹配字符结尾的字符\d 匹配一个数字的字符,和 [0-9] 语法一样\d+ 匹配多个数字字符串,和 [0-9]+ 语法一样\D 非数字,其他同 \d\D+ 非数字,其他同 \d+\w 英文字母或数字的字符串,和 [a-zA-Z0-9] 语法一样\w+ 和 [a-zA-Z0-9]+ 语法一样\W 非英文字母或数字的字符串,和 [^a-zA-Z0-9] 语法一样\W+ 和 [^a-zA-Z0-9]+ 语法一样\s 空格,和 [\n\t\r\f] 语法一样\s+ 和 [\n\t\r\f]+ 一样\S 非空格,和 [^\n\t\r\f] 语法一样\S+ 和 [^\n\t\r\f]+ 语法一样\b 匹配以英文字母,数字为边界的字符串\B 匹配不以英文字母,数值为边界的字符串a|b|c 匹配符合a字符 或是b字符 或是c字符 的字符串abc 匹配含有 abc 的字符串
- rename -v 's/Sam3/Stm32/' *.nc /*执行修改,并列出已重命名的文件*/
- rename 's/\.bak$//' *.bak
- rename 'y/A-Z/a-z/' *
- rename 's/[ ]+//g' *
- rename 's/^/jelline/' *
- rename 's/$/jelline/' *
更多推荐
所有评论(0)