linux tee 重定向_快樂的linux命令行-重定向

整理自《快樂的linux命令行一書》。

linux系統版本: Ubuntu 17.04

本章,我們將介紹命令行最酷的特性,叫做I/O重定向,通過這個工具,可以重定向命令的輸入輸出,命令的輸入來自文件,而輸出也存到文。也可以把多個命令連接起來組成一個強大而命令管道。我們將介紹以下命令:

cat:連接文件

sort : 排序文本行

uniq : 報到或省略重復行

grep : 打印匹配行

wc : 打印文件中的換行符,字和字節個數

head : 輸出文件第一部分

tail : 輸出文件最后一部分

1、標準輸入、輸出和錯誤

程序,比方說ls,實際上把他們的運行結果輸送到一個叫做標準輸出(stdout)的特殊文件,而他們的狀態信息則送到另一個叫做標準錯誤的文件(stderr)。默認情況下,標準輸出和標準錯誤都連接到屏幕,而不是保存到磁盤文件。除此之外,許多程序從一個叫做標準輸入(stdin)的設備得到輸入,默認情況下,標準輸入連接到鍵盤。

2、重定向標準輸出

重定向標準輸出到另一個文件除了屏幕,我們使用“>”重定向符,其后跟文件名,例如:

重定向輸出.png

我們將ls的輸出重定向到ls-output.txt文件中。現在 ,我們把目錄換成一個不存在的目錄:

重定向2.png

可以看到,我們輸出了一個錯誤信息,這條錯誤信息沒有重定向到文件中而是輸出到了屏幕上,因為“>”只是重定向了標準輸出,而沒有重定向標準錯誤,所以錯誤出現在了屏幕上,但此時我們的文件已經變了:

重定向3.png

可以發現文件大小變為了0.因為使用“>”重定向符重定向輸出結果時,目標文件總是從開頭被重寫。所以導致文件內容刪除,那么我們怎么能把重定向結果追加到文件內容后面呢,使用“>>”重定向符:

重定向4.png

可以看到,即使出現錯誤,我們的文件大小仍然沒有變為0.

3、重定向標準錯誤

我們使用如下的方式重定向標準錯誤:

重定向錯誤.png

可以看到,我們的錯誤被寫入了文件:

重定向錯誤.png

4、重定向標準輸出和錯誤到同一個文件

如果說2代表標準錯誤,那么我們可以用1代表標準輸出,比如:

重定向5.png

如果我們希望捕捉一個命令的所有輸出到一個文件,即同時重定向標準輸出和標準錯誤,有兩種方法來完成任務,首先是傳統的方法:

重定向5.png

我們在最后添加了2>&1參數,根據大小文件大小可以看出,輸出和錯誤都被重定向到ls-output.txt文件中了。

第二種方法更加精簡:

重定向輸出和錯誤2.png

5、處理不需要的輸出

有時候我們不想要一個命令的輸出結果,我們只想把它扔掉,我們只需要重定向輸出結果到一個特殊的叫做“dev/null”的文件。這個文件是系統設備,叫做位存儲桶,它可以接受輸入,并且對輸入不做任何處理:

處理不需要的輸出.png

6、cat --連接文件

cat命令讀取一個或多個文件,然后復制他們到標準輸出:

cat命令1.png

cat還可以用來連接文件,比如我們下載了一個大型文件,這個文件被分為好多部分,我們想把他們連接起來,用如下的命令:

cat連接文件.png

如果cat命令沒有接受任何參數,它會從標準輸入讀入數據,而標準輸入默認是鍵盤,所以它會等待我們輸入數據:

cat命令2.png

使用快捷鍵ctrl+d結束我們的輸入,由于沒有重定向輸出,所以它會將原話輸出到屏幕上,如下圖:

cat輸出.png

我們也可以將cat接受的輸入重定向到文件中,并用cat查看:

cat輸出2.png

7、管道線

命令可以從標準輸入讀取數據,然后再把數據送到標準輸出,命令的這種能力被一個shell特性所利用,這個特性叫做管道線,一個命令的標準輸出可以管道到另一個命令的標準輸入:

command1 | command2

比如我們將ls的的輸出結果當做標準輸入輸送到less命令:

管道線1.png

8、過濾器

管道線經常用來對數據完成復雜的操作,有可能會把幾個命令放在一起組成管道線。通常,以這種方式使用的命令稱為過濾器。過濾器接受輸入,以某種方式改變它,然后輸出它。比如sort過濾器,把目錄/bin和/usr/bin中的可執行程序聯合在一起,再把它們排序:

過濾器.png

另一個過濾器是uniq,可以報道或者忽略重復行,默認情況下,從數據列表中刪除任何重復行,如果我們想得到重復的數據列,在uniq命令上加上“-d ”選項:

uniq.png

9、wc--打印行、字和字節數

wc命令用來顯示文件所包含的行,字和字節數:

wc命令1.png

10、打印匹配行

grep是個很強大的程序,用來找到文件中的匹配文本。這樣使用grep命令:

grep pattern [file...]

這里的pattern指匹配模式,grep能夠匹配的模式很復雜, 可以是正則表達式,不過這里只展示一個基本的文本匹配,找到文件名中包含zip的所有文件:

grep.png

11、head/tail 打印文件的開頭結尾

head命令默認打印文件的前10行,也可以用-n指定打印的行數

而tail命令默認打印文件的后10行,也可以用-n指定打印的行數

head-tail.png

12、tee命令

linux提供了一個tee命令,允許我們保存管道線中的中間結果,并且使數據繼續順著管道線流動:

tee.png

上面的命令使我們在進行grep匹配之前,首先將中間結果,即ls的結果保存到ls.txt中。

如果你喜歡我寫的文章,可以幫忙給小編點個贊或者加個關注,我一定會互粉的!

如果大家對linux感興趣,歡迎跟小編進行交流,小編微信為sxw2251,加我要寫好備注喲!

我的微信

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/443265.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/443265.shtml
英文地址,請注明出處:http://en.pswp.cn/news/443265.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Java 診斷工具 Arthas 常見命令

基本概念 云原生這么多微服務,當然需要一個診斷利器來排查問題。 Arthas 是阿里開源的 Java 診斷工具,深受開發者喜愛。在線排查問題,無需重啟;動態跟蹤 Java 代碼;實時監控 JVM 狀態。Arthas 支持 JDK 6&#xff0c…

28和lba48命令格式區別_編譯Sass(命令行)

本文作者:開課吧無憂圖文編輯:開三金sass編譯有很多種方式,如命令行編譯模式、編輯器自動編譯、編譯軟件koala、sass-loader等。今天我們就先來看第一種:命令行編譯剛才我在test文件夾里面已經建立了一個style.scss文件&#xff0…

JAVA基礎編程代碼50個

【程序1】 題目:古典問題:有一對兔子,從出生后第3個月起每個月都生一對兔子,小兔子長到第三個月后每個月又生一對兔子,假如兔子都不死,問每個月的兔子對數為多少? 程序分析: 兔子…

爬蟲軟件python功能_Python 網絡爬蟲程序詳解

#!/usr/bin/python #調用pythonfrom sys import argv #導入sys是導入python解釋器和他環境相關的參數from os import makedirs,unlink,sep  #os主要提供對系統路徑,文件重命名和刪除文件所需的函數#makedirs是創建遞歸文件夾的函數。#比如說我們要創建一個新的目錄…

價錢轉換python_如何在python中轉換貨幣?

我正在做一個虛擬助手項目。我想讓它告訴我其他貨幣的美元匯率。我用beauthoulsoup編寫了以下代碼,它從給定的網站獲取數據,對其進行解析并在命令行中打印結果供我閱讀。但這只是美元對巴基斯坦盧比。如何修改程序,使其接受任何貨幣并告訴我該…

char qt 轉unicode_Qt QString 中文 char* UTF-8 QByteArray QTextCodec unicode gb2312 GBK 亂碼與轉碼問題...

2012-03-22 14:00175人閱讀評論(0)代碼如下:如果不不設全局的字符集是utf-8,那么網上一般的方法是可以轉的。如下程序中 #define DD 1的情況下;但是如果設置了全局的utf-8,再用以前的方法:QByteArraybaaaa.toLatin1();…

計算機圖形學考試題及答案_計算機圖形學考試題及答案

3、在圖形文件中,常用來描述圖形元素(點,線,圓,弧等);而在光柵掃描圖形顯示器中,采用顯示所有圖形。4、當三維物體用透視變換方程投影到觀察平面上,物體中不與觀察平面平行任一簇平行線投影成收…

子窗體中組合框聯動_一張表實現組合框聯動

嗨,大家中午好!最近,有網友給我私信,想要一個聯動的示例,一個有關于部門聯動的操作。其實關于聯動的操作有很多,可以是組合框的聯動,列表框聯動,組合框與列表框也可以聯動&#xff0…

中如何實現文字轉語音_錄音轉文字、文字轉語音,學會這一招就夠了!手把手教你如何操作...

閱讀文章時候想著有人可以把文章讀給我聽就好了,寫作時想著語音直接可以轉換成文字就好了,大家是不是有時會突然冒出這樣的想法?七十這些看似天真的想法,還真的有辦法解決,這里就手把手教你如何操作才能將的文字轉換成…

圖像 理想低通濾波_圖像處理之濾波(下)

[toc]目錄一、常規濾波低通高通帶通帶阻二、非局部均值濾波三、維納濾波四、卡爾曼濾波前言所謂濾波,其實就是從混合在一起的諸多信號中提取出所需要的信號。信號的分類:確定型信號,可以表示為確定的時間函數,可確定其在任何時刻的…

泰山行宮碧霞元君祠_臨清市泰山行宮碧霞元君祠5月4號(農歷三月三十日)舉行大型泰山奶奶接駕法會...

臨清是泰山奶奶的娘家,每年的四月泰山奶奶要回臨清省親臨清市道教協會定于2019年農歷三月三十(5月4號星期六)于臨清桑樹園泰山行宮碧霞元君祠舉行大型泰山奶奶迎鸞接駕廟會。屆時,將有架鼓會、云龍會、獅胞會、鋼叉會、高蹺會、天音會、彩船會、秧歌會等…

充分條件反過來是必要條件嗎_“充分必要條件”引發的現實思考

昨天看了一篇文章是介紹“充分條件和必要條件”,大致就是A能直接推導出B,那A就是B的充分條件。A不一定能推導出B,但是沒A一定推導不出B,那A就是B必要條件。舉個簡單的例子:對你好(A)與喜歡你&am…

手機游戲降低游戲延遲的軟件_怎么降低手機網絡延遲(減少網絡延遲的5個小技巧)...

在過去的幾十年里,用戶或開發人員并不擔心延遲。在上世紀90年代和本世紀初,個人互聯網連接速度要慢得多,因此發送請求和接收響應之間的延遲要遠遠小于下載完成所需的時間。如今,更高的帶寬連接使下載速度更快,因此延遲…

mysql常用的開發軟件下載_強烈推薦!14款經典的MySQL客戶端軟件

【IT168 評論】不用我說,大家都知道MySQL是一個怎么樣的數據庫。雖然它的命運比較坎坷,但是絲毫沒有影響到我們對MySQL的熱情。不論是個人程序或者網站,還是企業數據庫,MySQL的身影無處不在。無論做什么數據庫的開發,一…

mysql最大值最小值_mysql最大值,最小值,總和查詢與計數查詢

1、最大值查詢:mysql> select max(score) from 4a;------------| max(score) |------------| 93 |------------1 row in set (0.06 sec)2、最小值查詢:mysql> select max(4a.score),min(4inall.score) from 4a,4inall;-------------------…

阿里云 centos mysql_在阿里云的CentOS環境中安裝配置MySQL的教程

1 常規錯誤的yum安裝方法:在前文中記述了CentOS 6.5系統中通過yum方式快速地搭建了LNMP環境,那么是否也能在CentOS 7或CentOS 7.1系統中依葫蘆畫瓢安裝MySql5.6.24呢?答案是否定的。[roottypecodes ~]# yum -y install mysql mysql-server my…

mysql文件脫機_SQL數據庫的脫機與聯機操作

online : 可對數據庫進行訪問offline:數據庫無法使用1、使用查詢語句select state_desc from sysdatabases where name 數據庫名 2、使用databasepropertyex( database,property)函數select databasepropertyex( 數據庫 ,’ status )分離數據庫:EXEC…

dockerfile 安裝mysql_dockerfile構建mysql鏡像

使用dockerfile構建mysql,鏡像構建完成后,運行容器后,啟動mysql服務總是報錯Fatal error: Cant open and lock privilege tables: Table storage engine for db doesnt have this optionmysql安裝使用的官方的壓縮包mysql-5.7.20-linux-glibc…

ubunt11 安裝mysql_ubuntu 11.10安裝mysql

1. 安裝devadmdevserver:~$ sudo apt-get install mysql-server......The following NEW packages will be installed:libdbd-mysql-perl libdbi-perl libhtml-template-perl libmysqlclient16libnet-daemon-perl libplrpc-perl mysql-client-5.1 mysql-client-core-5.1mysql-c…

mysql 取交集 php_mysql 查詢結果取交集的方法

本文將詳細介紹MySQL中如何實現以SQL查詢返回的結果集取交集的實現方法,需要的朋友可以參考1MySQL中如何實現以下SQL查詢(SELECT S.NameFROM STUDENT S, TRANSCRIPT TWHERE S.StudId T.StudId AND T.CrsCode CS305)INTERSECT(SELECT S.NameFROM STUDENT S, TRANSC…