1、標準輸入、標準輸出、錯誤輸出概述
數據庫
1.標準輸入(stdin)是指令數據的輸入,代碼爲0,使用<或者<<,默認是鍵盤。bash
2.標準輸出(stdout)是指令執行成功返回的結果,代碼爲1,使用>或者>>,默認在屏幕顯示。ide
3.標準錯誤輸出(stderr)是指令執行失敗返回的錯誤信息,代碼爲2,使用2>或者2>>,默認是屏幕。spa
2、數據流重定向的使用
1."<":指定輸入的數據媒介來源(tr 'a-z' 'A-Z' < 文件名:將指定文件中的小寫字母變爲大寫字母輸出到屏幕)code
2.">"、"1>":將正確的內容覆蓋輸出到指定的媒介排序
3.">>"、"1>>":將正確的內容追加到指定的媒介ci
4."2>":將錯誤覆蓋輸出到指定的媒介it
5."2>>":將錯誤信息追加輸出到指定的媒介class
6."&>":將正確內容和錯誤信息覆蓋輸出到指定媒介搜索
7."&>>":將正確內容和錯誤信息追加到指定的媒介
8.多個指令執行
bash1&&bash2(前者執行成功纔會執行後者)
bash1||bash2(前者執行完畢且失敗才執行後者)
3、管道命令概述
1.管道命令可以將一個命令的執行結果通過篩選,只保留咱們須要的信息。 如,/etc目錄下會有大量的文件,若是使用ls很難找到須要的文件,所以可使用管道命令將ls的結果進行一次篩選,只保留須要的信息。
2.管道和數據流重定向的區別:
管道一詞很是生動形象,原始數據通過管道後,管道會將一部分不須要的信息過濾掉,只保留用戶所關注的信息。
數據流重定向是指定數據在哪裏顯示,默認狀況下會在屏幕顯示,咱們能夠指定它輸出到文件。
3.管道命令經過管道符"|"鏈接
4.可以接收標準輸入(stdin),如tail/more/grep等
5.可以接收來自前一個指令的數據成功stdin進行處理
4、管道命令的使用
1.cut:爲剪切的意思,它能將一行行的數據按照指定的分隔符切成一列列,而後只顯示特定列的數據.
cut -d '分隔符' -f n 按照特定的分隔符將數據切分,並只顯示第n列的數據。
cut -c 起始字符的下標-結束字符的下標 選擇特定範圍內的數據(cut中涉及的下標均從1開始)
2.grep:關鍵字查找
grep [-cinv] [--color=auto] '關鍵詞' 待查找的文件名
-c:統計關鍵詞出現的次數
-i:關鍵詞忽略大小寫
-n:輸出行號
-v:反向選擇,即查找不包含該關鍵字的行
--color=auto:關鍵詞高亮
命令 | grep [-參數] ‘關鍵詞’ 採用管道,將前一個命令的執行結果輸出給grep,並經過grep的關鍵詞搜索將符合條件的行搜索出來。
3.sort:排序
sort [-參數] 文件
-t:指定分隔符
-k:選取分隔符後的第幾個字段進行排序
-f:排序時忽略選取字段的大小寫
-b:取出選取字段前的空格
-M:將選取的字段按照月份來排序(前提是選取字段就是月份)
-n:將選取字段按照數據來排序(前提是選取字段就是數字)
-r:反向排序
-u:去重,若選取字段有重複,則去掉重複
命令 | sort [-參數] 使用管道,將前一個命令執行的結果按照指定字段進行排序。
4.uniq:只能用於管道,它可以去除前一個命令執行的結果中徹底同樣的行。
uniq [-參數] -i:忽略大小寫 -c:進行重複行的統計
5.wc:統計字數、行數、字符數
wc [-參數] 文件名
-l 列出行數
-w 列出字數
-c 列出字符數
6.tee:可以同時將命令執行的結果輸出到指定的文件和屏幕。只能結合管道使用
tee [-a] 文件 -a:以追加的形式寫入文件。
7.join:鏈接兩個文件
這個命令與管道無關。 它至關於數據庫中的join鏈接,將兩張表中指定字段,且字段相同的行鏈接起來。在這裏,它可以將兩個文件中指定字段的相同字段鏈接起來,併成一行。
join [-參數] 文件1 文件2
-t:兩個文件的字段分隔符
-1:第一個文件的字段
-2:第二個文件的字段
-i:忽略所選字段的大小寫
8.split:該命令能將一個大文件切分紅若干個小文件。
split [-參數] 大文件 小文件名字前綴
-b:指定小文件的大小,須要加上單位:b、k、m -l:指定每一個小文件中的行數。
大文件會被切分紅若干個小文件,且小文件的名字爲:小文件名字前綴+aa、小文件名字前綴+ab、小文件名字前綴+ac.