直接在終端中輸入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命令批量重命名文件
摘要: 本文介紹rename命令完成重命名批量文件語法,介紹了rename用到的Perl的替換和轉化形式,並給出常用正規表達式。最後給出幾個實例。偶爾會遇到需要重命名批量文件,最典型的例子就是數碼相機的相片,在Ubuntu可以用工具Purrr或者PerfixSuffix實現該功能,但重命名批量文件並不常用,為了偶爾的一次操作,安裝工具(可能通過Ubuntu Software Center或者sudo apt-get install安裝),加之圖形化界面操作也比較費時間。事實上,rename命令就可以出色完成該工作。
一、rename命令 Linux的 rename 命令有兩個版本(C語言和Perl語言),早期的Linux發行版基本上使用的是C語言版本,現在系統幾乎都是Perl語言版本了(支持正則處理,功能更強大)[1]。可以通過命令man rename打開rename幫助文檔查看版本,如果第一行內容如下,則是Perl語言版本。-v(verbose)打印被成功重命名的文件 -n(no-act)只是顯示將被重命名的文件,而不重命名(重命名之前可以用-n確認 需要重命名的文件) -f(force)覆蓋已經存在的文件 perlexprPerl語言格式的正則表達式 files需要被替換的文件(比如*.c、*.h),如果沒給出文件名,將從標准輸入讀先舉個例子來感受下,比如將當前目錄下所有*.nc文件中Sam3替換成Stm32,命令如下:
匹配:m// (可以省略m,直接寫成/regexp/) 替換:s/// 轉化:tr///博文[3]給出了8種模式,rename命令常用到替換和轉化兩種(用匹配也沒意義)。轉換跟替換不同,替換是將replacement整個字符串替換pattern字符串,而轉換則是用replacement逐個字符替換pattern逐個字符,結果依賴於replacement與pattern字符個數(見下述分析)。 (1)替換 替換表達方式如下[3],還有一系列參數,貌似不怎麼用得著。
eEvaluate the right side as an expression. gMatch globally, i.e. all occurrences. iCase-insensitive pattern matching. mTreat string as multiple lines. oOnly compile pattern once, even if variables within it change. sTreat string as single line. xUse extended regular expressions(2)轉化 轉化有兩種等價表達方式,如下:
cComplement the SEARCHLIST. dDelete found but unreplaced characters. sSquash duplicate replaced characters.轉化同替換不同,用REPLACEMENTLIST逐個字符替換SEARCHLIST逐個字符,比如'tr/Sam/Stm/',用S替代S,t替代a,m替代m。結果依賴於兩者字符長短,下面以文件名FastSpiSam3C.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 的字符串三、實例 3.1 將所有*.nc文件中Sam3替換成Stm32
更多Ubuntu相關信息見Ubuntu 專題頁面 http://www.linuxidc.com/topicnews.aspx?tid=2