2021-05-12 14:32:11
Ubuntu中rename命令和批次重新命名
2020-06-16 17:29:01
直接在終端中輸入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語言版本。
- RENAME(1) Perl Programmers Reference Guide RENAME(1)
鑑於Perl語言版本是主流,本文只介紹該版本下rename的用法,C語言版本操作見[1]。Perl語言版本的rename命令格式如下:
- rename [ -v ] [ -n ] [ -f ] perlexpr [ files ]
-v(verbose)列印被成功重新命名的檔案-n(no-act)只是顯示將被重新命名的檔案,而不重新命名(重新命名之前可以用-n確認需要重新命名的檔案)-f(force)覆蓋已經存在的檔案perlexprPerl語言格式的正規表示式files需要被替換的檔案(比如*.c、*.h),如果沒給出檔名,將從標準輸入讀
先舉個例子來感受下,比如將當前目錄下所有*.nc檔案中Sam3替換成Stm32,命令如下:
- rename -n 's/Sam3/Stm32/' *.nc /*確認需要重新命名的檔案*/
- rename -v 's/Sam3/Stm32/' *.nc /*執行修改,並列出已重新命名的檔案*/
整個命令的重點在於Perl語言正規表示式,下一部分將予以較詳細的介紹。
二、Perl正規表示式
2.1 三種形式[2]
匹配:m// (可以省略m,直接寫成/regexp/)替換:s///轉化:tr///
博文[3]給出了8種模式,rename命令常用到替換和轉化兩種(用匹配也沒意義)。轉換跟替換不同,替換是將replacement整個字串替換pattern字串,而轉換則是用replacement逐個字元替換pattern逐個字元,結果依賴於replacement與pattern字元個數(見下述分析)。
引數c、d、s把我搞懵了,本想通過一系列操作,總結規律,結果徒勞。
(1)替換
替換表達方式如下[3],還有一系列引數,貌似不怎麼用得著。
- s/PATTERN/REPLACEMENT/egimosx
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)轉化
轉化有兩種等價表達方式,如下:
- tr/SEARCHLIST/REPLACEMENTLIST/cds
- y/SEARCHLIST/REPLACEMENTLIST/cds
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為例進行說明:
- 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
2.2 常用模式
正規表示式中的一些常用模式pattern[2]:
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 非數位,其他同 dD+ 非數位,其他同 d+w 英文字母或數位的字串,和 [a-zA-Z0-9] 語法一樣w+ 和 [a-zA-Z0-9]+ 語法一樣W 非英文字母或數位的字串,和 [^a-zA-Z0-9] 語法一樣W+ 和 [^a-zA-Z0-9]+ 語法一樣s 空格,和 [ntrf] 語法一樣s+ 和 [ntrf]+ 一樣S 非空格,和 [^ntrf] 語法一樣S+ 和 [^ntrf]+ 語法一樣b 匹配以英文字母,數位為邊界的字串B 匹配不以英文???母,數值為邊界的字串a|b|c 匹配符合a字元 或是b字元 或是c字元 的字串abc 匹配含有 abc 的字串
三、範例
3.1 將所有*.nc檔案中Sam3替換成Stm32
- rename -v 's/Sam3/Stm32/' *.nc /*執行修改,並列出已重新命名的檔案*/
3.2 去掉檔案字尾名(比如去掉.bak)
- rename 's/.bak$//' *.bak
3.3 將檔名改為小寫
- rename 'y/A-Z/a-z/' *
3.4 去掉檔名的空格
- rename 's/[ ]+//g' *
3.5 檔案開頭加入字串(比如jelline)
- rename 's/^/jelline/' *
3.6 檔案末尾加入字串(比如jelline)
- rename 's/$/jelline/' *
相關文章