本文介紹下,linux中有關重定向及管道的相關知識,有基礎知識的介紹,也有經典執行個體參考,希望對大家有所幫助。
一,重定向
1.1 重定向符号
> 輸出重定向到一個檔案或裝置 覆寫原來的檔案
>! 輸出重定向到一個檔案或裝置 強制覆寫原來的檔案
>> 輸出重定向到一個檔案或裝置 追加原來的檔案
< 輸入重定向到一個程式
1.2标準錯誤重定向符号
2> 将一個标準錯誤輸出重定向到一個檔案或裝置 覆寫原來的檔案 b-shell
2>> 将一個标準錯誤輸出重定向到一個檔案或裝置 追加到原來的檔案
2>&1 将一個标準錯誤輸出重定向到标準輸出 注釋:1 可能就是代表 标準輸出
>& 将一個标準錯誤輸出重定向到一個檔案或裝置 覆寫原來的檔案 c-shell
|& 将一個标準錯誤 管道 輸送 到另一個指令作為輸入
1.3指令重導向示例
在 bash 指令執行的過程中,主要有三種輸出入的狀況,分别是:
1. 标準輸入;代碼為 0 ;或稱為 stdin ;使用的方式為 <
2. 标準輸出:代碼為 1 ;或稱為 stdout;使用的方式為 1>
3. 錯誤輸出:代碼為 2 ;或稱為 stderr;使用的方式為 2>
例子:
複制代碼代碼示例:
[test @test test]# ls -al > list.txt
将顯示的結果輸出到 list.txt 檔案中,若該檔案以存在則予以取代!
[test @test test]# ls -al >> list.txt
将顯示的結果累加到 list.txt 檔案中,該檔案為累加的,舊資料保留!
[test @test test]# ls -al 1> list.txt 2> list.err
将顯示的資料,正确的輸出到 list.txt 錯誤的資料輸出到 list.err
[test @test test]# ls -al 1> list.txt 2> &1
将顯示的資料,不論正确或錯誤均輸出到 list.txt 當中!錯誤與正确檔案輸出到同一個檔案中,則必須以上面的方法來寫!不能寫成其它格式!
[test @test test]# ls -al 1> list.txt 2> /dev/null
将顯示的資料,正确的輸出到 list.txt 錯誤的資料則予以丢棄! /dev/null ,可以說成是黑洞裝置。為空,即不儲存。
1.4為何要使用指令輸出重導向
當螢幕輸出的資訊很重要,而且我們需要将他存下來的時候;
背景執行中的程式,不希望他幹擾螢幕正常的輸出結果時;
一些系統的例行指令(例如寫在 /etc/crontab 中的檔案)的執行結果,希望他可以存下來時;
一些執行指令,我們已經知道他可能的錯誤訊息,是以想以『 2> /dev/null 』将他丢掉時;
錯誤訊息與正确訊息需要分别輸出時。
二,管線指令 ( pipe )
就如同前面所說的, bash 指令執行的時候有輸出的資料會出現,那麼如果這群資料必需要經過幾道手續之後才能得到我們所想要的格式,應該如何來設定?這就牽涉到管線指令的問題了( pipe ),管線指令使用的是『 | 』。
例子:簡單的管線指令
假設我們要讀取 last 這個指令中,那個 root 登入的『次數』應該怎麼作?
那麼我所進行的步驟是:
1. 執行 last ,将所有這個月的所有人登入資料取出來;
2. 使用 grep 将上面的輸出資料(stdout)當中的 root 撷取出來,其它的不要;
3. 使用 wc 這個可以計算行數的指令将上一步的資料計算行數!
由于 last 的輸出是一行代表一次登入,是以隻要計算幾行就代表登入幾次的意思,經由上面三個步驟,将 last 資料逐漸的篩選,就可以得到我們的資料了!整個指令可以寫成如下: [test @test bin]# last | grep root | wc -l
這個管線指令『 | 』僅能處理經由前面一個指令傳來的正确資訊,也就是standard output ( STDOUT ) 的資訊,對于 stdandard error 并沒有直接處理的能力。
2.1基本的管線指令指令介紹
cut
文法:[root @test /root ]# cut -d "分隔字元" [-cf] fields
參數說明:
-d :後面接的是用來分隔的字元,預設是『空格符』
-c :後面接的是『第幾個字元』
-f :後面接的是第幾個區塊?
範例:
複制代碼代碼示例: [root @test /root]# cat /etc/passwd | cut -d ":" -f 1
将 passwd 這個檔案裡面,每一行裡頭的 : 用來作為分隔号,而列出第一個區塊!也就是姓名所在啦!
[root @test /root]# last | cut -c1-20
将 last 之後的資料,每一行的 1-20 個字元取出來!
sort
文法:[root @test /root ]# sort [-t 分隔符] [(+起始)(-結束)] [-nru]
參數說明:
-t 分隔符:使用分隔符來隔開不同區間,預設是 tab
+start -end:由第 start 區間排序到 end 區間
-n :使用『純數字』排序(否則就會以文字型态來排序)
-r :反向排序
-u :相同出現的一行,隻列出一次!
範例:
複制代碼代碼示例: [root @test /root]# cat /etc/passwd | sort将列出來的個人賬号排序!
[root @test /root]# cat /etc/passwd | sort -t: +2n将個人賬号中,以使用者 ID 來排序(以 : 來分隔,第三個為 ID ,但第一個代号為 0 之故)
[root @test /root]# cat /etc/passwd | sort -t: +2nr反相排序啰!
wc
文法:[root @test /root ]# wc [-lmw]
參數說明:
-l :多少行
-m :多少字元
-w :多少字
範例:
複制代碼代碼示例: [root @test /root]# cat /etc/passwd | wc -l這個檔案裡頭有多少行?
[root @test /root]# cat /etc/passwd | wc -w這個檔案裡頭有多少字!?
uniq這個指令用來将『重複的行删除掉隻顯示一個』
文法:[root @test /root ]# uniq
範例:
複制代碼代碼示例: [root @test /root]# last | cut -d" " -f1 | sort | uniq
tee指令重定向到檔案的同時将資料顯示在螢幕上
文法:[root @test /root ]# last | tee last.list | cut -d " " -f1
範例:
複制代碼代碼示例: [root @test /root]# last | tee last.list | cut -d " " -f1
tr
文法:[root @test /root ]# tr [-ds] SET1
參數說明:
-d :删除 SET1 這個字元串
-s :取代掉重複的字元!
範例:
複制代碼代碼示例: [root @test /root]# last | tr '[a-z]' '[A-Z]' <==将小寫改成大寫
[root @test /root]# cat /etc/passwd | tr -d : <== : 這個符号在 /etc/passwd 中不見了!
[root @test /root]# cat /home/test/dostxt | tr -d '\r' > dostxt-noM
split
文法:[root @test /root ]# split [-bl] 輸入檔案 輸出檔案前導字元
參數說明:
-b :以檔案 size 來分
-l :以行數來分
範例:[root @test /root]# split -l 5 /etc/passwd test <==會産生 testaa, testab, testac... 等等的檔案
說明:在 Linux 底下就簡單的多了!你要将檔案分割的話,那麼就使用 -b size 來将一個分割的檔案限制其大小,如果是行數的話,那麼就使用 -l line 來分割!
管線指令在 bash 的連續的處理程式中是相當重要的!另外,在 log file 的分析當中也是相當重要的一環。
管道輸送到一個指令的标準輸入可以使用标準輸入參數”-“ 進行更仔細的控制.如cat指令的示例
例子:
複制代碼代碼示例: sort mylist | more
sort mylist | cat –n | lpr
pwd | cat – mylist | lpr 本文原始連結: http://www.jbxue.com/LINUXjishu/9768.html