Linux Shell

Linux Shell

Shell是系統的用戶界面,提供了用戶與核心進行互動操作的一種接口。它接收用戶輸入的命令並把它送入核心去執行。

實際上Shell是一個命令解釋器,它解釋由用戶輸入的命令並且把它們送到核心。不僅如此,Shell有自己的程式語言用於對命令的編輯,它允許用戶編寫由shell命令組成的程式。Shell程式語言具有普通程式語言的很多特點,比如它也有循環結構和分支控制結構等,用這種程式語言編寫的Shell程式與其他應用程式具有同樣的效果。

基本介紹

Shell 簡介,Shell 的使用,shell入門基礎必備,建立和運行shell程式,shell中的變數,shell中引號的使用方法,shell程式中的test命令,Linux主要shell命令詳解,什麼是shell,shell的種類,shell命令,shell中的特殊字元,標準輸入/輸出和重定向,linux shell 函式,

Shell 簡介

Shell是系統的用戶界面,提供了用戶與核心進行互動操作的一種接口。它接收用戶輸入的命令並把它送入核心去執行。
實際上Shell是一個命令解釋器,它解釋由用戶輸入的命令並且把它們送到核心。不僅如此,Shell有自己的程式語言用於對命令的編輯,它允許用戶編寫由shell命令組成的程式。Shell程式語言具有普通程式語言的很多特點,比如它也有循環結構和分支控制結構等,用這種程式語言編寫的Shell程式與其他應用程式具有同樣的效果。
Linux提供了像MicrosoftWindows那樣的可視的命令輸入界面--X Window圖形用戶界面GUI)。它提供了很多桌面環境系統,其操作就像Windows一樣,有視窗、圖示和選單,所有的管理都是通過滑鼠控制。GNOME
每個Linux系統的用戶可以擁有他自己的用戶界面或Shell,用以滿足他們自己專門的Shell需要。
同Linux本身一樣,Shell也有多種不同的版本。主要有下列版本的Shell: Bourne Shell:是貝爾實驗室開發的。
BASH:是GNU的Bourne Again Shell,是GNU作業系統上默認的shell。
Korn Shell:是對Bourne SHell的發展,在大部分內容上與Bourne Shell兼容。
C Shell:是SUN公司Shell的BSD版本。
Z Shell:The last shell you’ll ever need! Z是最後一個字母,也就是終極Shell。它集成了bash、ksh的重要特性,同時又增加了自己獨有的特性。

Shell 的使用

不論是哪一種Shell,它最主要的功用都是解譯使用者在命令列提示符號下輸入的指令。Shell 語法分析命令列,把它分解成以空白區分開的符號(token),在此空白包括了跳位鍵(tab)、空白和換行(New Line)。如果這些字包含了metacharacter,shell 將會評估(evaluate)它們的正確用法。另外,shell 還管理檔案輸入輸出及幕後處理(background processing)。在處理命令列之後,shell 會尋找命令並開始執行它們。
Shell 的另一個重要功用是提供個人化的使用者環境,這通常在 shell 的初始化檔案中完成(.profile、.login、.cshrc、.tcshrc 等等)。這些檔案包括了設定終端機鍵盤和定義視窗的特徵;設定變數,定義搜尋路徑、許可權、提示符號和終端機類型;以及設定特殊應用程式所需要的變數,例如視窗、文字處理程式、及程式語言的程式庫。Korn shell 和 C shell 加強了個別化的能力:增加歷程、別名、和內建變數集以避免使用者誤殺檔案、不慎簽出、並在當工作完成時通知使用者。
Shell 也能當解譯性的程式語言(interpreted programing language)。Shell 程式,通常叫做命令檔案,它由列在檔案內的命令所構成。此程式在編輯器中編輯(雖然也可以直接在命令列下寫作程式,online scripting),由 UNIX 命令和基本的程式結構,例如變數的指定、測試條件、和循環所構成。您不需要編譯 shell 命令檔。Shell 本身會解譯命令檔中的每一行,就如同由鍵盤輸入一樣。shell 負責解譯命令,而使用者則必須了解這些命令能做什麼。下面列出了一些有用的命令和它們的使用方法。

shell入門基礎必備

建立和運行shell程式

什麼是shell程式呢? 簡單的說shell程式就是一個包含若干行shell或者linux命令的檔案.
像編寫高級語言的程式一樣,編寫一個shell程式需要一個文本編輯器.如Ⅵ等.
在文本編輯環境下,依據shell的語法規則,輸入一些shell/linux命令行,形成一個完整的程式檔案.
執行shell程式檔案有三種方法
⑴#chmod +x file(在/etc/profile中,加入export PATH=${PATH}:~/yourpath,就可以在命令行下直接運行,像執行普通命令一樣)
⑵#sh file
⑶# . file
⑷#source file
在編寫shell時,第一行一定要指明系統需要那種shell解釋你的shell程式,如:#! /bin/bash,#! /bin/csh,/bin/tcsh,還是#! /bin/pdksh .

shell中的變數

⑴常用系統變數
$ # :保存程式命令行參數的數目
$ ?:保存前一個命令的返回碼
$ 0 :保存程式名
$ * :以("$1 $2...")的形式保存所有輸入的命令行參數
$ @ :以("$1""$2"...)的形式保存所有輸入的命令行參數
⑵定義變數
shell語言是非類型的解釋型語言,不象用C++/JAVA語言編程時需要事先聲明變數.給一個變數賦值,實際上就是定義了變數.
linux支持的所有shell中,都可以用賦值符號(=)為變數賦值.
如:
abc=9 (bash/pdksh不能在等號兩側留下空格)
set abc = 9 (tcsh/csh)
由於shell程式的變數是無類型的,所以用戶可以使用同一個變數時而存放字元時而存放整數.
如:
name=abc (bash/pdksh)
set name = abc (tcsh)
在變數賦值之後,只需在變數前面加一個$去引用.如:
echo $name
⑶位置變數
當運行一個支持多個命令行參數的shell程式時,這些變數的值將分別存放在位置變數里.
其中第一個參數存放在位置變數1,第二個參數存放在位置變數2,依次類推...,shell保留
這些變數,不允許用戶以令外的方式定義他們.同別的變數,用$符號引用他們.

shell中引號的使用方法

shell使用引號(單引號/雙引號)和反斜線("\")用於向shell解釋器禁止一些特殊字元.
反引號(")對shell則有特殊意義.
如:
abc="how are you" (bash/pdksh)
set abc = "how are you" (tcsh)
這個命令行把三個單詞組成的字元串how are you作為一個整體賦值給變數abc.
abc1='$LOGNAME,how are you!' (bash/pdksh)
set abc1='$LOGNAME,how are you!' (tcsh)
abc2="$LOGNAME,how are you!" (bash/pdksh)
set abc2="$LOGNAME,how are you!" (tcsh)
LOGNAME變數是保存當前用戶名的shell變數,假設他的當前值是:wang.執行完兩條命令後,
abc1的內容是:$LOGNAME,how are you!.而abc2的內容是;wang,how are you!.
象單引號一樣,反斜線也能禁止所有特殊字元.但是他一次只能禁止一個字元.而不能禁止
一組字元.
反引號的功能不同於以上的三種符號.他不具有禁止特殊字元的功能.但是可以通過他將
一個命令的運行結果傳遞給另外一個命令.
如:
contents=`ls` (bash/pdksh)
set contents = `ls` (tcsh)

shell程式中的test命令

在bash/pdksh中,命令test用於計算一個條件表達式的值.他們經常在條件語句和循環
語句中被用來判斷某些條件是否滿足.
test命令的語法格式:
test expression
或者
[expression]
在test命令中,可以使用很多shell的內部操作符.這些操作符介紹如下:
⑴字元串操作符 用於計算字元串表達式
test命令 | 含義
Str1 = str2 | 當str1與str2相同時,返回True
Str1! = str2| 當str1與str2不同時,返回True
Str | 當str不是空字元時,返回True
-n str | 當str的長度大於0時,返回True
-z str | 當str的長度是0時,返回True
⑵整數操作符具有和字元操作符類似的功能.只是他們的操作是針對整數
test表達式 | 含義
Int1 -eq int2|當int1等於int2時,返回True
Int1 -ge int2|當int1大於/等於int2時,返回True
Int1 -le int2|當int1小於/等於int2時,返回True
Int1 -gt int2|當int1大於int2時,返回True
Int1 -ne int2|當int1不等於int2時,返回True
⑶用於檔案操作的操作符,他們能檢查:檔案是否存在,檔案類型等
test表達式 | 含義
-d file |當file是一個目錄時,返回 True
-f file |當file是一個普通檔案時,返回 True
-r file |當file是一個可讀檔案時,返回 True
-s file |當file檔案長度大於0時,返回 True
-w file |當file是一個可寫檔案時,返回 True
-x file |當file是一個執行檔時,返回 True
⑷shell的邏輯操作符用於修飾/連線包含整數,字元串,檔案操作符的表達式
test表達式 | 含義
! expr |當expr的值是False時,返回True
Expr1 -a expr2|當expr1,expr2值同為True時,返回True
Expr1 -o expr2|當expr1,expr2的值至少有一個為True時,返回True
注意:
tcsh shell 不使用test命令,但是tcsh中的表達式同樣能承擔相同的功能.tcsh
支持的表達式於C中的表達式相同.通常使用在if和while命令中.
tcsh表達式 | 含義
Int1 <= int2 |當int1小於/等於int2時,返回True
Int1 >= int2 |當int1大於/等於int2時,返回True
Int1 < int2 |當int1小於int2時,返回True
Int1 > int2 |當int1大於int2時,返回True
Str1 == str2 |當str1與str2相同時,返回True
Str1 != str2 |當str1與str2不同時,返回True
-r file |當file是一個可讀檔案時,返回True
-w file |當file是一個可寫檔案時,返回True
-x file |當file是一個執行檔時,返回True
-e file |當file存在時,返回True
-o file |當file檔案的所有者是當前用戶時,返回True
-z file |當file長度為0時,返回True
-f file |當file是一個普通檔案時,返回True
-d file |當file是一個目錄時,返回True
Exp1 || exp2 |當exp1和exp2的值至少一個為True時,返回True
Exp1 && exp2 |當exp1和exp2的值同為True時,返回True
! exp |當exp的值為False時,返回True

Linux主要shell命令詳解

shell是用戶和Linux作業系統之間的接口。Linux中有多種shell,其中預設使用的是Bash。本章講述了shell的工作原理,shell的種類,shell的一般操作及Bash的特性。

什麼是shell

Linux系統的shell作為作業系統的外殼,為用戶提供使用作業系統的接口。它是命令語言、命令解釋程式程式設計語言的統稱。
shell是用戶和Linux核心之間的接口程式,如果把Linux核心想像成一個球體的中心,shell就是圍繞核心的外層。當從shell或其他程式向Linux傳遞命令時,核心會做出相應的反應。
shell是一個命令語言解釋器,它擁有自己內建的shell命令集,shell也能被系統中其他應用程式所調用。用戶在提示符下輸入的命令都由shell先解釋然後傳給Linux核心。
有一些命令,比如改變工作目錄命令cd,是包含在shell內部的。還有一些命令,例如拷貝命令cp和移動命令mv,是存在於檔案系統中某個目錄下的單獨的程式。對用戶而言,不必關心一個命令是建立在shell內部還是一個單獨的程式。
shell首先檢查命令是否是內部命令,若不是再檢查是否是一個應用程式(這裡的應用程式可以是Linux本身的實用程式,如ls和rm,也可以是購買的商業程式,如xv,或者是自由軟體,如emacs)。然後shell在搜尋路徑里尋找這些應用程式(搜尋路徑就是一個能找到可執行程式的目錄列表)。如果鍵入的命令不是一個內部命令並且在路徑里沒有找到這個執行檔,將會顯示一條錯誤信息。如果能夠成功找到命令,該內部命令或應用程式將被分解為系統調用並傳給Linux核心。
shell的另一個重要特性是它自身就是一個解釋型的程式設計語言,shell程式設計語言支持絕大多數在高級語言中能見到的程式元素,如函式、變數、數組和程式控制結構。shell程式語言簡單易學,任何在提示符中能鍵入的命令都能放到一個可執行的shell程式中。
當普通用戶成功登錄,系統將執行一個稱為shell的程式。正是shell進程提供了命令行提示符。作為默認值(TurboLinux系統默認的shell是BASH),對普通用戶用“$”作提示符,對超級用戶(root)用“#”作提示符。
一旦出現了shell提示符,就可以鍵入命令名稱及命令所需要的參數。shell將執行這些命令。如果一條命令花費了很長的時間來運行,或者在螢幕上產生了大量的輸出,可以從鍵盤上按ctrl+c發出中斷信號來中斷它(在正常結束之前,中止它的執行)。
當用戶準備結束登錄對話進程時,可以鍵入logout命令、exit命令或檔案結束符(EOF)(按ctrl+d實現),結束登錄。
我們來實習一下shell是如何工作的。
$ make work
make:***No rule to make target ‘work’. Stop.
$
注釋:make是系統中一個命令的名字,後面跟著命令參數。在接收到這個命令後,shell便執行它。本例中,由於輸入的命令參數不正確,系統返回信息後停止該命令的執行。
在例子中,shell會尋找名為make的程式,並以work為參數執行它。make是一個經常被用來編譯大程式的程式,它以參數作為目標來進行編譯。在 “make work”中,make編譯的目標是work。因為make找不到以work為名字的目標,它便給出錯誤信息表示運行失敗,用戶又回到系統提示符下。
另外,用戶鍵入有關命令行後,如果shell找不到以其中的命令名為名字的程式,就會給出錯誤信息。例如,如果用戶鍵入:
$ myprog
bash:myprog:command not found
$
可以看到,用戶得到了一個沒有找到該命令的錯誤信息。用戶敲錯命令後,系統一般會給出這樣的錯誤信息。

shell的種類

Linux中的shell有多種類型,其中最常用的幾種是Bourne shell(sh)、C shell(csh)和Korn shell(ksh)。三種shell各有優缺點。Bourne shell是UNⅨ最初使用的shell,並且在每種UNⅨ上都可以使用。Bourne shell在shell編程方面相當優秀,但在處理與用戶的互動方面做得不如其他幾種shell。Linux作業系統預設的shell是Bourne Again shell,它是Bourne shell的擴展,簡稱Bash,與Bourne shell完全向後兼容,並且在Bourne shell的基礎上增加、增強了很多特性。Bash放在/bin/bash中,它有許多特色,可以提供如命令補全、命令編輯和命令歷史表等功能,它還包含了很多C shell和Korn shell中的優點,有靈活和強大的編程接口,同時又有很友好的用戶界面
C shell是一種比Bourne shell更適於編程的shell,它的語法與C語言很相似。Linux為喜歡使用C shell的人提供了Tcsh。Tcsh是C shell的一個擴展版本。Tcsh包括命令行編輯、可程式單詞補全、拼寫校正、歷史命令替換、作業控制和類似C語言的語法,它不僅和Bash shell是提示符兼容,而且還提供比Bash shell更多的提示符參數。
Korn shell集合了C shell和Bourne shell的優點並且和Bourne shell完全兼容。Linux系統提供了pdksh(ksh的擴展),它支持任務控制,可以在命令行上掛起、後台執行、喚醒或終止程式。
Linux並沒有冷落其他shell用戶,還包括了一些流行的shell如ash、zsh等。每個shell都有它的用途,有些shell是有專利的,有些能從Internet網上或其他來源獲得。要決定使用哪個shell,只需讀一下各種shell的在線上幫助,並試用一下。
用戶在登錄到Linux時由/etc/passwd檔案來決定要使用哪個shell。例如:
# fgrep lisa /etc/passwd
lisa:x:500:500:TurboLinux User:/home/lisa:/bin/bash
shell被列每行的末尾(/bin/bash)。
由於Bash是Linux上預設的shell,本章主要介紹Bash及其相關知識。

shell命令

命令行c
用戶登錄到Linux系統時,可以看到一個shell提示符,標識了命令行的開始。用戶可以在提示符後面輸入任何命令及參數。例如:
$ date
二 11 23 01:34:58 CST 1999
$
用戶登錄時,實際進入了shell,它遵循一定的語法將輸入的命令加以解釋並傳給系統。命令行中輸入的第一個字必須是一個命令的名字,第二個字是命令的選項或參數,命令行中的每個字必須由空格或TAB隔開,格式如下:
$ Command Option Arguments
⒈ 選項和參數
選項是包括一個或多個字母的代碼,它前面有一個減號(減號是必要的,Linux用它來區別選項和參數),選項可用於改變命令執行的動作的類型。例如:
$ ls
motd passwd
$
這是沒有選項的ls命令,可列出當前目錄中所有檔案,只列出各個檔案的名字,而不顯示其他更多的信息。
$ ls -l
total 2
-rw-r--r-- 2 wzh book 22 Apr 20 20:37 motd
-rw-r--r-- 2 wzh book 796 Apr 20 20:37 passwd
$
加入-l選項,將會為每個檔案列出一行信息,諸如數據大小和數據最後被修改的時間。
大多數命令都被設計為可以接納參數。參數是在命令行中的選項之後鍵入的一個或多個單詞,例如:
$ ls -l text
-rw-r--r-- 2 wzh book 22 Apr 20 20:37 motd
-rw-r--r-- 2 wzh book 796 Apr 20 20:37 passwd
$
將顯示text目錄下的所有檔案及其信息。
有些命令,如ls可以帶參數,而有一些命令可能需要一些最小數目的參數。例如,cp命令至少需要兩個參數,如果參數的數目與命令要求不符,shell將會給出出錯信息。例如:
$ cp -i mydata newdata
注意:命令行中選項先於參數輸入。
⒉ 命令行特徵
命令行實際上是可以編輯的一個文本緩衝區,在按回車之前,可以對輸入的文本進行編輯。比如利用BACKSPACE鍵可以刪除剛鍵入的字元,可以進行整行刪除,還可以插入字元,使得用戶在輸入命令,尤其是複雜命令時,若出現鍵入錯誤,無須重新輸入整個命令,只要利用編輯操作,即可改正錯誤。
利用上箭頭可以重新顯示剛執行的命令,利用這一功能可以重複執行以前執行過的命令,而無須重新鍵入該命令。
bash保存著以前鍵入過的命令的列表,這一列表被稱為命令歷史表。按動上箭頭,便可以在命令行上逐次顯示各條命令。同樣,按動下箭頭可以在命令列表中向下移動,這樣可以將以前的各條命令顯示在命令行上,用戶可以修改並執行這些命令。這一特徵將在10.4節中進行詳細的論述。
在一個命令行中還可以置入多個命令,用分號將各個命令隔開。例如:
$ ls -F;cp -i mydata newdata
也可以在幾個命令行中輸入一個命令,用反斜槓將一個命令行持續到下一行。
$ cp –i
mydata
newdata
上面的cp命令是在三行中輸入的,開始的兩行以反斜槓結束,把三行作為一個命令行。

shell中的特殊字元

shell中除使用普通字元外,還可以使用一些具有特殊含義和功能的特殊字元。在使用它們時應注意其特殊的含義和作用範圍。下面分別對這些特殊字元加以介紹。
⒈ 通配符
通配符用於模式匹配,如檔案名稱匹配、路經名搜尋、字元串查找等。常用的通配符有*、?和括在方括弧[ ]中的字元序列。用戶可以在作為命令參數的檔案名稱中包含這些通配符,構成一個所謂的“模式串”,在執行過程中進行模式匹配。
* 代表任何字元串(長度可以不等),例如:“f*”匹配以f打頭的任意字元串。但應注意,檔案名稱前的圓點(.)和路經名中的斜線(/)必須顯式匹配。例如“*”不能匹配.file,而“.*”才可以匹配.file。
? 代表任何單個字元
[] 代表指定的一個字元範圍,只要檔案名稱中[ ]位置處的字元在[]中指定的範圍之內,那么這個檔案名稱就與這個模式串匹配。方括弧中的字元範圍可以由直接給出的字元組成,也可以由表示限定範圍的起始字元、終止字元及中間的連字元(-)組成。例如,f [a- d] 與f [abcd]的作用相同。Shell將把與命令行中指定的模式串相匹配的所有檔案名稱都作為命令的參數,形成最終的命令,然後再執行這個命令。
下面我們給出表10-1說明這些通配符的具體含義。
表10-1 通配符含義舉例
模式串
意 義
*
當前目錄下所有檔案的名稱。
*Text*
當前目錄下所有檔案名稱中包含有Text的檔案的名稱。
[ab-dm]*
當前目錄下所有以a、b、c、d、m開頭的檔案的名稱。
[ab-dm]?
當前目錄下所有以a、b、c、d、m開頭且後面只跟有一個字元的檔案的名稱。
/usr/bin/??
目錄/usr/bin下所有名稱為兩個字元的檔案的名稱。
特別需要注意的是,連字元“-”僅在方括弧內有效,表示字元範圍,如在方括弧外面就成為普通字元了。而*和?只在方括弧外面是通配符,若出現在方括弧之內,它們也失去通配符的能力,成為普通字元了。例如,模式“- a[*?]abc”中只有一對方括弧是通配符,*和?均為普通字元,因此,它匹配的字元串只能是- a*abc和- a?abc。
最後說明一下使用通配符時需要注意的一些問題。由於*、?和[]對於shell來說具有比較特殊的意義,因此在正常的檔案名稱中不應出現這些字元。特別是在目錄名中不要出現它們,否則Shell匹配起來可能會無窮的遞歸下去。另外要注意的一點是:如果目錄中沒有與指定的模式串相匹配的檔案名稱,那么Shell將使用此模式串本身作為參數傳給有關命令。這可能就是命令中出現特殊字元的原因所在。
⒉ 引號
在shell中引號分為三種:單引號,雙引號和反引號。
* 單引號 ‘
由單引號括起來的字元都作為普通字元出現。特殊字元用單引號括起來以後,也會失去原有意義,而只作為普通字元解釋。例如:
$ string=’$PATH’
$ echo $string
$PATH
$
可見$保持了其本身的含義,作為普通字元出現。
* 雙引號 “
由雙引號括起來的字元,除$、、’、和”這幾個字元仍是特殊字元並保留其特殊功能外,其餘字元仍作為普通字元對待。對於$來說,就是用其後指定的變數的值來代替這個變數和$;對於而言,是轉義字元,它告訴shell不要對其後面的那個字元進行特殊處理,只當作普通字元即可。可以想見,在雙引號中需要在前面加上的只有四個字元$,,’和”本身。而對”號,若其前面沒有加,則Shell會將它同前一個”號匹配。
例如,我們假定PATH的值為.:/usr/bin:/bin,輸入如下命令:
$ TestString=”$PATH\”$PATH”
$ echo $TestString
.:/usr/bin:/ bin”$PATH
$
讀者可以自己試一下在第二個雙引號之前不加會產生什麼結果。
* 反引號 `
反引號(`)這個字元所對應的鍵一般位於鍵盤的左上角,不要將其同單引號(’)混淆。反引號括起來的字元串被shell解釋為命令行,在執行時,shell首先執行該命令行,並以它的標準輸出結果取代整個反引號(包括兩個反引號)部分。例如:
$ pwd
/home/xyz
$ string=”current directory is `pwd`”
$ echo $string
current directour is /home/xyz
$
shell執行echo命令時,首先執行`pwd`中的命令pwd,並將輸出結果/home/xyz取代`pwd`這部分,最後輸出替換後的整個結果。
利用反引號的這種功能可以進行命令置換,即把反引號括起來的執行結果賦值給指定變數。例如:
$ today=`date`
$ echo Today is $today
Today is Mon Apr 15 16:20:13 CST 1999
$
反引號還可以嵌套使用。但需注意,嵌套使用時內層的反引號必須用反斜線()將其轉義。例如:
$ abc=`echo The number of users is `who| wc-l``
$ echo $abc
The number of users is 5
$
在反引號之間的命令行中也可以使用shell的特殊字元。Shell為得到``中命令的結果,它實際上要去執行``中指定的命令。執行時,命令中的特殊字元,如$,”,?等又將具有特殊含義,並且``所包含的可以是任何一個合法的Shell命令,如:
$ ls
note readme.txt Notice Unix.dir
$ TestString=”`echo $HOME ` ` ls [nN]*`”
$ echo $TestString
/home/yxz note Notice
$
其他情況,讀者可自行試之。
⒈ 注釋符
在shell編程中經常要對某些正文行進行注釋,以增加程式的可讀性。在Shell中以字元“#”開頭的正文行表示注釋行。
此外還有一些特殊字元如:用於輸入/輸出重定向與管道的<;、>;、<<;、>>;和|;執行後台命令的&;;命令執行操作符&&;和||及表示命令組的{}將在下面各小節中加以介紹。

標準輸入/輸出和重定向

⒈ 標準輸入與輸出
我們知道,執行一個shell命令行時通常會自動打開三個標準檔案,即標準輸入檔案(stdin),通常對應終端的鍵盤;標準輸出檔案(stdout)和標準錯誤輸出檔案(stderr),這兩個檔案都對應終端的螢幕。進程將從標準輸入檔案中得到輸入數據,將正常輸出數據輸出到標準輸出檔案,而將錯誤信息送到標準錯誤檔案中。
我們以cat命令為例,cat命令的功能是從命令行給出的檔案中讀取數據,並將這些數據直接送到標準輸出。若使用如下命令:
$ cat config
將會把檔案config的內容依次顯示到螢幕上。但是,如果cat的命令行中沒有參數,它就會從標準輸入中讀取數據,並將其送到標準輸出。例如:
$ cat
Hello world
Hello world
Bye
Bye
<ctrl+d>
$
用戶輸入的每一行都立刻被cat命令輸出到螢幕上。
另一個例子,命令sort按行讀入檔案正文(當命令行中沒有給出檔案名稱時,表示從標準輸入讀入),將其排序,並將結果送到標準輸出。下面的例子是從標準輸入讀入一個採購單,並將其排序。
$ sort
bananas
carrots
apples
<ctrl+d>
apples
bananas
carrots
$
這時我們在螢幕上得到了已排序的採購單。
直接使用標準輸入/輸出檔案存在以下問題:
輸入數據從終端輸入時,用戶費了半天勁輸入的數據只能用一次。下次再想用這些數據時就得重新輸入。而且在終端上輸入時,若輸入有誤修改起來不是很方便。
輸出到終端螢幕上的信息只能看不能動。我們無法對此輸出作更多處理,如將輸出作為另一命令的輸入進行進一步的處理等。
為了解決上述問題,Linux系統為輸入、輸出的傳送引入了另外兩種機制,即輸入/輸出重定向和管道。
⒉ 輸入重定向
輸入重定向是指把命令(或可執行程式)的標準輸入重定向到指定的檔案中。也就是說,輸入可以不來自鍵盤,而來自一個指定的檔案。所以說,輸入重定向主要用於改變一個命令的輸入源,特別是改變那些需要大量輸入的輸入源。
例如,命令wc統計指定檔案包含的行數、單詞數和字元數。如果僅在命令行上鍵入:
$ wc
wc將等待用戶告訴它統計什麼,這時shell就好象死了一樣,從鍵盤鍵入的所有文本都出現在螢幕上,但並沒有什麼結果,直至按下<ctrl+d>;,wc才將命令結果寫在螢幕上。
如果給出一個檔案名稱作為wc命令的參數,如下例所示,wc將返回該檔案所包含的行數、單詞數和字元數。
$ wc /etc/passwd
20 23 726 /etc/passwd
$
另一種把/etc/passwd檔案內容傳給wc命令的方法是重定向wc的輸入。輸入重定向的一般形式為:命令<;檔案名稱。可以用下面的命令把wc命令的輸入重定向為/etc/passwd檔案:
$ wc < /etc/passwd
20 23 726
$
另一種輸入重定向稱為here文檔,它告訴shell當前命令的標準輸入來自命令行。here文檔的重定向操作符使用<<;。它將一對分隔設定(本例中用delim表示)之間的正文重定向輸入給命令。下例將一對分隔設定delim之間的正文作為wc命令的輸入,統計出正文的行數、單詞數和字元數。
$ wc<<delim
>this text forms the content
>of the here document,which
>continues until the end of
>text delimter
>delim
4 17 98
在<<;操作符後面,任何字元都可以作為正文開始前的分隔設定,本例中使用delim作為分隔設定。here文檔的正文一直延續到遇見另一個分隔設定為止。第二個分隔設定應出現在新行的開頭。這時here文檔的正文(不包括開始和結束的分隔設定)將重新定向送給命令wc作為它的標準輸入。
由於大多數命令都以參數的形式在命令行上指定輸入檔案的檔案名稱,所以輸入重定向並不經常使用。儘管如此,當要使用一個不接受檔案名稱作為輸入參數的命令,而需要的輸入內容又存在一個檔案里時,就能用輸入重定向解決問題。
⒈ 輸出重定向
輸出重定向是指把命令(或可執行程式)的標準輸出或標準錯誤輸出重新定向到指定檔案中。這樣,該命令的輸出就不顯示在螢幕上,而是寫入到指定檔案中。
輸出重定向比輸入重定向更常用,很多情況下都可以使用這種功能。例如,如果某個命令的輸出很多,在螢幕上不能完全顯示,那么將輸出重定向到一個檔案中,然後再用文本編輯器打開這個檔案,就可以查看輸出信息;如果想保存一個命令的輸出,也可以使用這種方法。還有,輸出重定向可以用於把一個命令的輸出當作另一個命令的輸入(還有一種更簡單的方法,就是使用管道,將在下面介紹)。
輸出重定向的一般形式為:命令>;檔案名稱。例如:
$ ls > directory.out
$ cat directory.out
ch1.doc ch2.doc ch3.doc chimp config mail/ test/
$
將ls命令的輸出保存為一個名為directory.out的檔案。
註:如果>;符號後邊的檔案已存在,那么這個檔案將被重寫。
為避免輸出重定向中指定檔案只能存放當前命令的輸出重定向的內容,shell提供了輸出重定向的一種追加手段。輸出追加重定向與輸出重定向的功能非常相似,區別僅在於輸出追加重定向的功能是把命令(或可執行程式)的輸出結果追加到指定檔案的最後,而該檔案原有內容不被破壞。
如果要將一條命令的輸出結果追加到指定檔案的後面,可以使用追加重定向操作符>>;。形式為:命令>>;檔案名稱。例如:
$ ls *.doc>>directory.out
$ cat directory.out
ch1.doc ch2.doc ch3.doc chimp config mail/ test/
ch1.doc ch2.doc ch3.doc
$
和程式的標準輸出重定向一樣,程式的錯誤輸出也可以重新定向。使用符號2>;(或追加符號2>>;)表示對錯誤輸出設備重定向。例如下面的命令:
$ ls /usr/tmp 2> err.file
可在螢幕上看到程式的正常輸出結果,但又將程式的任何錯誤信息送到檔案err.file中,以備將來檢查用。
還可以使用另一個輸出重定向操作符(&>;)將標準輸出和錯誤輸出同時送到同一檔案中。例如:
$ ls /usr/tmp &> output.file
利用重定向將命令組合在一起,可實現系統單個命令不能提供的新功能。例如使用下面的命令序列:
$ ls /usr/bin > /tmp/dir
$ wc –w < /tmp/dir
459
統計了/usr/bin目錄下的檔案個數。
管 道
將一個程式或命令的輸出作為另一個程式或命令的輸入,有兩種方法,一種是通過一個臨時檔案將兩個命令或程式結合在一起,例如上個例子中的/tmp/dir檔案將ls和wc命令聯在一起;另一種是Linux所提供的管道功能。這種方法比前一種方法更好。
管道可以把一系列命令連線起來,這意味著第一個命令的輸出會作為第二個命令的輸入通過管道傳給第二個命令,第二個命令的輸出又會作為第三個命令的輸入,以此類推。顯示在螢幕上的是管道行中最後一個命令的輸出(如果命令行中未使用輸出重定向)。
通過使用管道符“|”來建立一個管道行。用管道重寫上面的例子:
$ ls /usr/bin|wc -w
1789
再如:
$ cat sample.txt|grep "High"|wc -l
管道將cat命令(列出一個檔案的內容)的輸出送給grep命令。grep命令在輸入里查找單詞High,grep命令的輸出則是所有包含單詞High的行,這個輸出又被送給wc命令,wc命令統計出輸入中的行數。假設sample.txt檔案的內容如下:
Things to do today:
Low:Go grocery shopping
High:Return movie
High:Clear level 3 in Alien vs. Predator
Medium:Pick up clothes from dry cleaner
那么該管道行的結果是2。
命令替換
命令替換和重定向有些相似,但區別在於命令替換是將一個命令的輸出作為另外一個命令的參數。常用命令格式為:
command1 `command2`
其中,command2的輸出將作為command1的參數。需要注意的是這裡的`符號,被它括起來的內容將作為命令執行,執行後的結果作為command1的參數。例如:
$ cd `pwd`
該命令將pwd命令列出的目錄作為cd命令的參數,結果仍然是停留在當前目錄下。

linux shell 函式

在shell中可以定義函式。函式實際上也是由若干條shell命令組成的,因此它與shell程式形式上是相似的,不同的是它不是一個單獨的進程,而是shell程式的一部分。函式由兩部分組成:函式名和函式體
n函式定義的格式為:
函式名()
{
命令集合
}
n或者
function 函式名()
{
命令集合
}
Shell函式與腳本的區別
Shell函式和shell程式比較相似,它們的區別在於:
Shell程式在子Shell中運行
而Shell函式在當前Shell中運行。因此在當前Shell中可以看到Shell函式對變數的修改。

相關詞條

熱門詞條

聯絡我們