來自:IBM developerWorks
連結:https://www.ibm.com/developerworks/cn/aix/library/au-unixtips/
使用檔案名自動補全功能 (file name completion)。
使用歷史擴充套件。
重用以前的引數。
使用 pushd 和 popd 管理目錄導航。
查詢大型檔案。
不使用編輯器建立臨時檔案。
使用 curl 命令列實用工具。
最有效地利用正則運算式。
確定當前使用者。
使用 awk 處理資料。
檔案名自動補全功能讓你無需在命令提示符處鍵入各種又臭又長的檔案名,避免輸入錯誤,提高效率。這個功能在各個 Shell 中的工作方式略有不同,所以首先請確定自己用的是哪種shell。
可以使用 echo $0 或 ps -p $$ 命令顯示您正在使用的 Shell。
List1:確定你的shell
$ echo $0
-bash
$ ps –p $$
PID TTY TIME CMD
6344 ttys000 0:00.02 –bash
C Shell 支援最直接檔案名補全功能。設定 filec 變數即可啟用該功能(使用命令 set filec)。在您開始鍵入檔案名後,可以按 Esc 鍵,Shell 將補全檔案名或者補全盡可能多的部分。例如,假設有名為 file1、file2 和 file3 的檔案。如果鍵入 f,然後按 Esc 鍵,將填充 file,之後你需要輸入 1、2 或 3 來完成相應的檔案名。
Bash Shell 也提供了檔案名補全功能,但它使用 的是Tab 鍵。您在 Bash Shell 中不需要設定任何選項即可啟用檔案名補全功能,該選項是預設設定的。Bash 還實現了其他功能。鍵入檔案名的一部分後,按 Tab 鍵,如果有多個檔案滿足您的請求,並且您需要新增文字以選擇其中一個檔案,那麼您可以多按 Tab 鍵兩次,以顯示與您目前鍵入的內容相匹配的檔案的串列。
用之前名為 file1、file2 和 file3 的檔案示例,首先鍵入 f。當按一次 Tab 鍵時,Bash 自動補全顯示file;再按一次 Tab 鍵時,將展開串列 file1 file2 file3。
對於 Korn Shell 使用者,檔案名補全功能取決於 EDITOR 變數的值。如果 EDITOR 設定為 vi,那麼您鍵入部分名稱,然後按 Esc 鍵後跟反斜槓 () 字元。如果 EDITOR 設定為 emacs,那麼您鍵入部分名稱,然後按兩次 Esc 鍵以補全檔案名。
如果你的一系列命令都用了相同的檔案名,會發生什麼情況?有一種快捷方式可以快速獲得你上次使用的檔案名。如List 2 所示,!$ 命令傳回前一個命令使用的檔案名。
從檔案 this-is-a-long-lunch-menu-file.txt 中搜索單詞 pickles 的出現位置。搜尋結束後,用 vi 命令來編輯 this-is-a-long-lunch-menu-file.txt 檔案,而不需要重新鍵入檔案名。用感嘆號 (!) 來訪問歷史,然後使用美元符號 ($) 傳回前一命令的最後欄位。如果你需要反覆用到長檔案名,那麼這是一個非常好的工具。
List2:用 !$ 獲得前一個命令使用的檔案名
$ grep pickles this-is-a-long-lunch-menu-file.txt
pastrami on rye with pickles and onions
$ vi !$
!$ 命令傳回某個命令使用的上一個檔案名引數。但如果某個命令使用多個檔案名,而您只希望重用其中一個檔案名,該如何做?
!:1 運運算元傳回某個命令使用的第一個檔案名。
List 3 中的示例顯示可以如何將此運運算元與 !$ 運運算元組合使用。在第一個命令中,將一個檔案重新命名為更有意義的名稱,但為了保持原始檔案名可用,建立了一個符號連結。重新命名檔案 kxp12.c 以提高可讀性,然後使用 link 命令來建立到原始檔案名的符號連結,以防在其他位置使用該檔案名。!$ 運運算元傳回 file_system_access.c 檔案名,而 !:1 運運算元傳回 kxp12.c 檔案名,該檔案名是上個命令的第一個檔案名。
List3:組合使用 !$ 和 !:1
$ mv kxp12.c file_system_access.c
$ ln –s !$ !:1
UNIX 支援各種目錄導航工具,我最喜歡的兩款提高工作效率的工具是 pushd 和 popd。您肯定知道 cd 命令用於更改當前目錄。如果要在多個目錄中導航,但希望能夠快速傳回某個位置,該如何做?
pushd 和 popd 命令建立一個虛擬目錄堆疊,pushd 命令用來更改您的當前目錄並將其儲存在堆疊中,而 popd 命令用來從堆疊的頂部移除目錄並使您傳回該位置。可以使用 dirs 命令來顯示當前目錄堆疊。
List4:使用 pushd 和 popd 在目錄樹中導航
$ pushd .
~ ~
$ pushd /etc
/etc ~ ~
$ pushd /var
/var /etc ~ ~
$ pushd /usr/local/bin
/usr/local/bin /var /etc ~ ~
$ dirs
/usr/local/bin /var /etc ~ ~
$ popd
/var /etc ~ ~
$ popd
/etc ~ ~
$ popd
~ ~
$ popd
pushd 和 popd 命令還支援使用引數處理目錄堆疊。使用 +n 或 -n 引數,其中 n 是一個數字,可以向左或向右移動堆疊:
List5:旋轉目錄堆疊
$ dirs
/usr/local/bin /var /etc ~ ~
$ pushd +1
/var /etc ~ ~ /usr/local/bin
$ pushd -1
~ /usr/local/bin /var /etc ~
有時候需要找出磁碟空間到底被什麼佔用了?可以使用以下幾個工具來管理儲存裝置。df 命令顯示每個可用捲上已使用的塊的總數以及空閑空間的百分比。
List6:確定各捲的使用情況
$ df
Filesystem 512-blocks Used Available Capacity Mounted on
/dev/disk0s2 311909984 267275264 44122720 86% /
devfs 224 224 0 100% /dev
fdesc 2 2 0 100% /dev
map -hosts 0 0 0 100% /net
map auto_home 0 0 0 100% /home
要查詢大型檔案?用 find 命令時附帶 -size 引數。List 7 顯示瞭如何使用 find 命令來查詢大於 10MB 的檔案。註意,-size 引數以 KB 為單位計量大小。
List7:查詢大於10MB的所有檔案
$ find / -size +10000k –xdev –exec ls –lh {};
下麵是個簡單示例:需要快速建立一個簡單臨時檔案,但不想啟動編輯器。使用帶有 > 檔案重定向運運算元的 cat 命令。
如List 8所示,使用不帶檔案名的 cat 命令只回顯向標準輸入鍵入的任何內容;> 重定向將該輸入捕獲到指定的檔案中。註意,在結束輸入時必須提供檔案結束字元,一般是 Ctrl-D。
List8:快速建立臨時檔案
$ cat > my_temp_file.txt
This is my temp file text
^D
$ cat my_temp_file.txt
This is my temp file text
要執行相同操作,但是附加到現有檔案而不是建立新檔案。如List 9 所示,改用 >> 運運算元。>> 檔案重定向運運算元向現有檔案附加內容。
List9:快速向檔案附加內容
$ cat >> my_temp_file.txt
More text
^D
$ cat my_temp_file.txt
This is my temp file text
More text
想從命令列訪問 Web?用 curl 命令!curl 命令使您可以使用 HTTP、HTTPS、FTP、FTPS、Gopher、DICT、TELNET、LDAP 或 FILE 協議從伺服器檢索資料。
例如,用 curl 命令來下載 HTTP 託管的檔案。使用 -o 引數來指定儲存輸出的位置“
List10:用 curl 下載檔案
$ curl -o archive.tar http://www.somesite.com/archive.tar
curl命令非常強大,可以透過man curl瞭解更多它的功能 。
大量 UNIX 命令使用正則運算式作為引數。從技術角度而言,正則運算式是表示某種樣式的字串(也就是說,由字母、數字和符號組成的字元序列),用於定義零或更長的字串。正則運算式使用元字元(例如,星號 [*] 和問號 [?])來匹配其他字串的部分或全部內容。正則運算式不一定包含萬用字元,但萬用字元可以使正則運算式在搜尋樣式和處理檔案時發揮更大的作用。表 1 顯示了一些基本正則運算式序列。
表 1. 正則運算式序列
序列 | 說明 |
---|---|
脫字元 (^) | 匹配出現在行首的運算式,例如 ^A |
美元符號 ($) | 匹配出現在行末的運算式,例如 A$ |
反斜槓 () | 取消下一個字元的特殊含義,例如 ^ |
方括號 ([]) | 匹配括起來的任一字元,例如 [aeiou](使用連字元 [-] 表示範圍,例如 [0-9])。 |
[^ ] | 匹配除括起來字元以外的任一字元,例如 [^0-9] |
句點 (.) | 匹配除行尾之外的任意單個字元 |
星號 (*) | 匹配零個或多個前驅字元或運算式 |
{x,y} | 匹配出現過 x 到 y 個和前面相同的內容 |
{x} | 精確匹配出現過 x 個和前面相同的內容 |
{x,} | 匹配出現過 x 個或更多和前面相同的內容 |
以下是經常與 grep 命令一起使用的一些基本正則運算式:
List11:使用正則運算式和 grep
$ # Lists your mail
$ grep ‘^From: ‘ /usr/mail/$USER
$ # Any line with at least one letter
$ grep ‘[a-zA-Z]’ search-file.txt
$ # Anything not a letter or number
$ grep ‘[^a-zA-Z0-9] search-file.txt
$ # Find phone numbers in the form 999-9999
$ grep ‘[0-9]{3}-[0-9]{4}’ search-file.txt
$ # Find lines with exactly one character
$ grep ‘^.$’ search-file.txt
$ # Find any line that starts with a period “.”
$ grep ‘^.’ search-file.txt
$ # Find lines that start with a “.” and 2 lowercase letters
$ grep ‘^.[a-z][a-z]’ search-file.txt
有時查詢問題是,需要確定某個特定使用者是否執行過您的管理指令碼。為找出答案,您可以使用 whoami 命令來傳回當前使用者的名稱:
List12:從命令列使用 whoami
$ whoami
John
List13:用 whoami 確保當前使用者不是根使用者的 Bash 指令碼
if [ $(whoami) = “root” ]
then
echo “You cannot run this script as root.”
exit 1
fi
awk 命令似乎始終處在 Perl 的陰影下,但它對於簡單、基於命令列的資料處理來說是一個快速、實用的工具。List 14 展示瞭如何開始使用 awk 命令。
若要獲取檔案中每行文字的長度,用 length() 函式。若要檢視字串 ing 是否出現在檔案文字中,請用 index() 函式,該函式傳回 ing 首次出現的位置,這樣您就可以使用它來進行進一步的字串處理。若要 tokenize(也就是說,將一行拆分為單詞長度的片段)某個字串,請使用 split() 函式。
List14:基本awk處理
$ cat text
testing the awk command
$ awk ‘{ i = length($0); print i }’ text
23
$ awk ‘{ i = index($0,”ing”); print i}’ text
5
$ awk ‘BEGIN { i = 1 } { n = split($0,a,” “); while (i <= n) {print a[i]; i++;} }' text
testing
the
awk
command
列印文字檔案中的指定欄位是一項簡單的 awk 任務。在List 15中,sales 檔案包含每個銷售人員的姓名,後跟每月銷售數字。可以使用 awk 命令來快速獲得每個月的銷售總額。預設情況下,awk 將每個以逗號分隔的值視為不同的欄位。用 $n 運運算元來訪問每個欄位。
List15:用awk對資料進行彙總
$cat sales
Gene,12,23,7
Dawn,10,25,15
Renee,15,13,18
David,8,21,17
$ awk -F, ‘{print $1,$2+$3+$4}’ sales
Gene 42
Dawn 50
Renee 46
David 46
awk 命令可以很複雜並應用於廣泛的情景中。
●本文編號400,以後想閱讀這篇文章直接輸入400即可
●輸入m獲取到文章目錄
運維
更多推薦《18個技術類公眾微信》
涵蓋:程式人生、演演算法與資料結構、駭客技術與網路安全、大資料技術、前端開發、Java、Python、Web開發、安卓開發、iOS開發、C/C++、.NET、Linux、資料庫、運維等。