通過使用 tr,您可以非常容易地實現 sed 的許多最基本功能。您可以將 tr 看作為 sed 的(極其)簡化的變體:它可以用一個字元來替換另一個字元,或者可以完全除去一些字元。您也可以用它來除去重復字元。這就是所有 tr 所能夠做的。
tr用來從標准輸入中通過替換或刪除操作進行字元轉換。tr主要用於刪除文件中控制字元或進行字元轉換。使用tr時要轉換兩個字元串:字元串1用於查詢,字元串2用於處理各種轉換。tr剛執行時,字元串1中的字元被映射到字元串2中的字元,然後轉換操作開始。
帶有最常用選項的tr命令格式為:
代碼如下:
tr -c -d -s ["string1_to_translate_from"] ["string2_to_translate_to"] input-file
這里:
-c 用字元串1中字元集的補集替換此字元集,要求字元集為ASCII。
-d 刪除字元串1中所有輸入字元。
-s 刪除所有重復出現字元序列,只保留第一個;即將重復出現字元串壓縮為一個字元串。
input-file是轉換文件名。雖然可以使用其他格式輸入,但這種格式最常用。
字元范圍
指定字元串1或字元串2的內容時,只能使用單字元或字元串范圍或列表。
[a-z] a-z內的字元組成的字元串。
[A-Z] A-Z內的字元組成的字元串。
[0-9] 數字串。
octal 一個三位的八進制數,對應有效的ASCII字元。
[O*n] 表示字元O重復出現指定次數n。因此[O*2]匹配OO的字元串。
tr中特定控制字元的不同表達方式
速記符含義八進制方式
a Ctrl-G 鈴聲07
b Ctrl-H 退格符10
f Ctrl-L 走行換頁14
n Ctrl-J 新行12
r Ctrl-M 回車15
t Ctrl-I tab鍵11
v Ctrl-X 30
表達字元串的特殊序列
String1 和 String2 變數中所包含的字元串可以使用以下的約定來表示:
如果某個字元在 String1 中被指定過多次,則該字元就被轉換成 String2 中為與 String1 中最後出現的字元相對應的字元。
如果由 String1 和 String2 指定的字元串長度不相同,則 tr 命令就會忽略較長一個字元串中的多餘字元。
標志
退出狀態
該命令返回以下出口值:
實例:
1、將文件file中出現的"abc"替換為"xyz"
復制代碼
代碼如下:
# cat file | tr "abc" "xyz" new_file
【注意】這里,凡是在file中出現的"a"字母,都替換成"x"字母,"b"字母替換為"y"字母,"c"字母替換為"z"字母。而不是將字元串"abc"替換為字元串"xyz"。
2、使用tr命令「統一」字母大小寫
(小寫 -- 大寫)
代碼如下:
# cat file | tr [a-z] [A-Z] new_file
(大寫 -- 小寫)
代碼如下:
# cat file | tr [A-Z] [a-z] new_file
3、把文件中的數字0-9替換為a-j
代碼如下:
# cat file | tr [0-9] [a-j] new_file
4、刪除文件file中出現的"Snail"字元
代碼如下:
# cat file | tr -d "Snail" new_file
【注意】這里,凡是在file文件中出現的'S','n','a','i','l'字元都會被刪除!而不是緊緊刪除出現的"Snail」字元串。
5、刪除文件file中出現的換行'n'、製表't'字元
代碼如下:
# cat file | tr -d "nt" new_file
不可見字元都得用轉義字元來表示的,這個都是統一的。
6、刪除「連續著的」重復字母,只保留第一個
代碼如下:
# cat file | tr -s [a-zA-Z] new_file
7、刪除空行
代碼如下:
# cat file | tr -s "n" new_file
8、刪除Windows文件「造成」的'^M'字元
代碼如下:
# cat file | tr -d "r" new_file
或者
代碼如下:
# cat file | tr -s "r" "n" new_file
【注意】這里-s後面是兩個參數"r"和"n",用後者替換前者
9、用空格符40替換製表符11
代碼如下:
# cat file | tr -s "11" "40" new_file
10、把路徑變數中的冒號":",替換成換行符"n"
代碼如下:
# echo $PATH | tr -s ":" "n"
11、若要將大括弧轉換為小括弧,請輸入:
代碼如下:
tr '{}' '()' textfile newfile
這便將每個 {(左大括弧)轉換成 ((左小括弧),並將每個 }(右大括弧)轉換成 )(右小括弧)。所有其它的字元都保持不變。
12、若要將大括弧轉換成方括弧,請輸入:
代碼如下:
tr '{}' '[]' textfile newfile
這便將每個 {(左大括弧)轉換成 [(左方括弧),並將每個 }(右大括弧)轉換成 ](右方括弧)。左方括弧必須與一個 ""(反斜扛)轉義字元一起輸入。
13、若要將小寫字元轉換成大寫,請輸入:
代碼如下:
tr 'a-z' 'A-Z' textfile newfile
14、若要創建一個文件中的單詞列表,請輸入:
代碼如下:
tr -cs '[:lower:][:upper:]' '[n*]' textfile newfile
這便將每一序列的字元(除大、小寫字母外)都轉換成單個換行符。*(星號)可以使 tr 命令重復換行符足夠多次以使第二個字元串與第一個字元串一樣長。
15、若要從某個文件中刪除所有空字元,請輸入:
代碼如下:
tr -d '' textfile newfile
16、若要用單獨的換行替換每一序列的一個或多個換行,請輸入:
代碼如下:
tr -s 'n' textfile newfile
或
代碼如下:
tr -s '12' textfile newfile
17、若要以「?」(問號)替換每個非列印字元(有效控制字元除外),請輸入:
代碼如下:
tr -c '[:print:][:cntrl:]' '[?*]' textfile newfile
這便對不同語言環境中創建的文件進行掃描,以查找當前語言環境下不能列印的字元。
18、要以單個「#」字元替換 字元類中的每個字元序列,請輸入:
代碼如下:
tr -s '[:space:]' '[#*]'
② linux在vim下怎麼批量替換或者注釋
方法一 塊選擇模式
插入注釋:
用v進入virtual模式
在10 - 20行添加 # 注釋
:10,20s/^/#/g
在10 - 20行刪除 # 注釋
:10,20s/^/#/g
注意例子中正則的分割符使用的是相反的符號,如果匹配// 那麼使用 #作分隔符這樣不需要對/作轉義處理,節省輸入次數。
③ Linux下的shell編程 如何替換文件中的內容
可以這樣做:
方法1:sed -i 's/被替換的內容/要替換成的內容/' file
方法2:sed 's/被替換的內容/要替換成的內容/g' file > file.out;mv file.out file。
(3)linux替換命令擴展閱讀:
Shell編程的常用技巧:
一、自動補齊:在linux中對於命令或路徑,可以TAB鍵進行自動補全,以下事項需要注意:
1、只存在一個該輸入字元開頭的命令或路徑,此時自動補全;
2、存在多個該輸入字元開頭的命令或路徑,此時第一次點擊TAB鍵無效廳鍵中,此時再次點扮山擊TAB會羅列出所有該字元開頭的命令或路徑,繼續輸入直到僅僅剩一個時自動補全;
3、如果命令已經是完整的,TAB鍵則是本來的移動功能;而路徑的話要看命令自身的行為決定後續動作。
二、歷史命令
1、history命令可以顯示歷史執行過的命令;
2、使用!+序號執行該序號對應的命令;
3、使用!+字元執亮岩行該字元開頭的最後一次執行的指令。
三、命令別名
1、實現別名:alias ddd="df -Th";
2、刪除別名:unalias ddd;
3、顯示所有別名命令列表:alias;
4、存放位置:~/.bashrc (加入該文件後,重啟後不會消失)。
四、重定向
1、重定向標准輸入:< 命令接收輸入的途徑由鍵盤改為文件;
2、重定向標准輸出:> 將命令的執行結果輸出到指定文件,而不是直接顯示到屏幕;
3、重定向標准輸出:>> 將命令的執行結果追加輸出到指定文件;
4、重定向標准錯誤:2> 清除指定文件的內容,並把標准錯誤信息保存到指定文件;
5、重定向標准錯誤:2>> 標准錯誤信息追加到指定文件;
6、重定向標准輸出和標准錯誤:&> 將標准輸出、標准錯誤信息全部保存到指定文件,而不是直接顯示在屏幕上。