自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

培養(yǎng)這10個習(xí)慣,你就離UNIX高手更進(jìn)一步了!

系統(tǒng) Linux
本文提出了 10 個值得采用的 UNIX 命令行習(xí)慣——幫助您克服許多常見使用怪癖,并在該過程中提高命令行工作效率的好習(xí)慣,讓你成為更高效的 UNIX 命令行高手。下面列出了這 10 個好習(xí)慣,之后對進(jìn)行了更詳細(xì)的描述。

[[214796]]

本文提出了 10 個值得采用的 UNIX 命令行習(xí)慣——幫助您克服許多常見使用怪癖,并在該過程中提高命令行工作效率的好習(xí)慣,讓你成為更高效的 UNIX 命令行高手。下面列出了這 10 個好習(xí)慣,之后對進(jìn)行了更詳細(xì)的描述。

10個好習(xí)慣

  1. 使用文件名自動補全功能 (file name completion)。
  2. 使用歷史擴(kuò)展。
  3. 重用以前的參數(shù)。
  4. 使用 pushd 和 popd 管理目錄導(dǎo)航。
  5. 查找大型文件。
  6. 不使用編輯器創(chuàng)建臨時文件。
  7. 使用 curl 命令行實用工具。
  8. 最有效地利用正則表達(dá)式。
  9. 確定當(dāng)前用戶。
  10. 使用 awk 處理數(shù)據(jù)。

1. 文件名自動補全

文件名自動補全功能讓你無需在命令提示符處鍵入各種又臭又長的文件名,避免輸入錯誤,提高效率。這個功能在各個 Shell 中的工作方式略有不同,所以首先請確定自己用的是哪種shell。

我正在運行哪種 Shell?

可以使用 echo $0 或 ps -p $$ 命令顯示您正在使用的 Shell。

List1:確定你的shell

 

  1. $ echo $0 
  2. -bash 
  3. $ ps –p $$ 
  4. PID TTY           TIME CMD 
  5. 6344 ttys000    0:00.02 –bash 

C Shell

C Shell 支持最直接文件名補全功能。設(shè)置 filec 變量即可啟用該功能(使用命令 set filec)。在您開始鍵入文件名后,可以按 Esc 鍵,Shell 將補全文件名或者補全盡可能多的部分。例如,假設(shè)有名為 file1、file2 和 file3 的文件。如果鍵入 f,然后按 Esc 鍵,將填充 file,之后你需要輸入 1、2 或 3 來完成相應(yīng)的文件名。

Bash

Bash Shell 也提供了文件名補全功能,但它使用 的是Tab 鍵。您在 Bash Shell 中不需要設(shè)置任何選項即可啟用文件名補全功能,該選項是缺省設(shè)置的。Bash 還實現(xiàn)了其他功能。鍵入文件名的一部分后,按 Tab 鍵,如果有多個文件滿足您的請求,并且您需要添加文本以選擇其中一個文件,那么您可以多按 Tab 鍵兩次,以顯示與您目前鍵入的內(nèi)容相匹配的文件的列表。

用之前名為 file1、file2 和 file3 的文件示例,首先鍵入 f。當(dāng)按一次 Tab 鍵時,Bash 自動補全顯示file;再按一次 Tab 鍵時,將展開列表 file1 file2 file3。

Korn Shell

對于 Korn Shell 用戶,文件名補全功能取決于 EDITOR 變量的值。如果 EDITOR 設(shè)置為 vi,那么您鍵入部分名稱,然后按 Esc 鍵后跟反斜杠 (\) 字符。如果 EDITOR 設(shè)置為 emacs,那么您鍵入部分名稱,然后按兩次 Esc 鍵以補全文件名。

2. 使用歷史擴(kuò)展

如果你的一系列命令都用了相同的文件名,會發(fā)生什么情況?有一種快捷方式可以快速獲得你上次使用的文件名。如List 2 所示,!$ 命令返回前一個命令使用的文件名。

從文件 this-is-a-long-lunch-menu-file.txt 中搜索單詞 pickles 的出現(xiàn)位置。搜索結(jié)束后,用 vi 命令來編輯 this-is-a-long-lunch-menu-file.txt 文件,而不需要重新鍵入文件名。用感嘆號 (!) 來訪問歷史,然后使用美元符號 ($) 返回前一命令的***字段。如果你需要反復(fù)用到長文件名,那么這是一個非常好的工具。

List2:用 !$ 獲得前一個命令使用的文件名

 

  1. $ grep pickles this-is-a-long-lunch-menu-file.txt 
  2.  
  3. pastrami on rye with pickles and onions 
  4.  
  5. $ vi !$ 

3. 重用以前的參數(shù)

!$ 命令返回某個命令使用的上一個文件名參數(shù)。但如果某個命令使用多個文件名,而您只希望重用其中一個文件名,該如何做?

!:1 操作符返回某個命令使用的***個文件名。

List 3 中的示例顯示可以如何將此操作符與 !$ 運算符組合使用。在***個命令中,將一個文件重新命名為更有意義的名稱,但為了保持原始文件名可用,創(chuàng)建了一個符號鏈接。重新命名文件 kxp12.c 以提高可讀性,然后使用 link 命令來創(chuàng)建到原始文件名的符號鏈接,以防在其他位置使用該文件名。!$ 操作符返回 file_system_access.c 文件名,而 !:1 操作符返回 kxp12.c 文件名,該文件名是上個命令的***個文件名。

List3:組合使用 !$ 和 !:1

 

  1. $ mv kxp12.c file_system_access.c 
  2.  
  3. $ ln –s !$ !:1 

4. 使用 pushd 和 popd 管理目錄導(dǎo)航

UNIX 支持各種目錄導(dǎo)航工具,我最喜歡的兩款提高工作效率的工具是 pushd 和 popd。您肯定知道 cd 命令用于更改當(dāng)前目錄。如果要在多個目錄中導(dǎo)航,但希望能夠快速返回某個位置,該如何做?

pushd 和 popd 命令創(chuàng)建一個虛擬目錄堆棧,pushd 命令用來更改您的當(dāng)前目錄并將其存儲在堆棧中,而 popd 命令用來從堆棧的頂部移除目錄并使您返回該位置??梢允褂?dirs 命令來顯示當(dāng)前目錄堆棧。

List4:使用 pushd 和 popd 在目錄樹中導(dǎo)航

 

  1. $ pushd . 
  2.  
  3. ~ ~ 
  4.  
  5. $ pushd /etc 
  6.  
  7. /etc ~ ~ 
  8.  
  9. $ pushd /var 
  10.  
  11. /var /etc ~ ~ 
  12.  
  13. $ pushd /usr/local/bin 
  14.  
  15. /usr/local/bin /var /etc ~ ~ 
  16.  
  17. $ dirs 
  18.  
  19. /usr/local/bin /var /etc ~ ~ 
  20.  
  21. $ popd 
  22.  
  23. /var /etc ~ ~ 
  24.  
  25. $ popd 
  26.  
  27. /etc ~ ~ 
  28.  
  29. $ popd 
  30.  
  31. ~ ~ 
  32.  
  33. $ popd 

pushd 和 popd 命令還支持使用參數(shù)處理目錄堆棧。使用 +n 或 -n 參數(shù),其中 n 是一個數(shù)字,可以向左或向右移動堆棧:

List5:旋轉(zhuǎn)目錄堆棧

 

  1. $ dirs 
  2.  
  3. /usr/local/bin /var /etc ~ ~ 
  4.  
  5. $ pushd +1 
  6.  
  7. /var /etc ~ ~ /usr/local/bin 
  8.  
  9. $ pushd -1 
  10.  
  11. ~ /usr/local/bin /var /etc ~ 

5. 查找大型文件

有時候需要找出磁盤空間到底被什么占用了?可以使用以下幾個工具來管理存儲設(shè)備。df 命令顯示每個可用卷上已使用的塊的總數(shù)以及空閑空間的百分比。

List6:確定各卷的使用情況

  1. $ df 
  2.  
  3. Filesystem                            512-blocks      Used  Available Capacity  Mounted on 
  4.  
  5. /dev/disk0s2                         311909984 267275264   44122720    86%    / 
  6.  
  7. devfs                                                224             224                 0   100%    /dev 
  8.  
  9. fdesc                                                2                     2                 0   100%    /dev 
  10.  
  11. map -hosts                                       0                     0                 0   100%    /net 
  12.  
  13. map auto_home                               0                     0                 0   100%    /home 

要查找大型文件?用 find 命令時附帶 -size 參數(shù)。List 7 顯示了如何使用 find 命令來查找大于 10MB 的文件。注意,-size 參數(shù)以 KB 為單位計量大小。

List7:查找大于10MB的所有文件

 

  1. $ find / -size +10000k –xdev –exec ls –lh {}\; 

6. 不要用編輯器創(chuàng)建臨時文件

下面是個簡單示例:需要快速創(chuàng)建一個簡單臨時文件,但不想啟動編輯器。使用帶有 > 文件重定向操作符的 cat 命令。

如List 8所示,使用不帶文件名的 cat 命令只回顯向標(biāo)準(zhǔn)輸入鍵入的任何內(nèi)容;> 重定向?qū)⒃撦斎氩东@到指定的文件中。注意,在結(jié)束輸入時必須提供文件結(jié)束字符,一般是 Ctrl-D。

List8:快速創(chuàng)建臨時文件

  1. $ cat > my_temp_file.txt 
  2.  
  3. This is my temp file text 
  4.  
  5. ^D 
  6.  
  7. $ cat my_temp_file.txt 
  8.  
  9. This is my temp file text 

要執(zhí)行相同操作,但是附加到現(xiàn)有文件而不是創(chuàng)建新文件。如List 9 所示,改用 >> 操作符。>> 文件重定向操作符向現(xiàn)有文件附加內(nèi)容。

List9:快速向文件附加內(nèi)容

  1. $ cat >> my_temp_file.txt 
  2.  
  3. More text 
  4.  
  5. ^D 
  6.  
  7. $ cat my_temp_file.txt 
  8.  
  9. This is my temp file text 
  10.  
  11. More text 

7. 使用 curl 命令行實用工具

想從命令行訪問 Web?用 curl 命令!curl 命令使您可以使用 HTTP、HTTPS、FTP、FTPS、Gopher、DICT、TELNET、LDAP 或 FILE 協(xié)議從服務(wù)器檢索數(shù)據(jù)。

例如,用 curl 命令來下載 HTTP 托管的文件。使用 -o 參數(shù)來指定保存輸出的位置“

List10:用 curl 下載文件

  1. $ curl -o archive.tar http://www.somesite.com/archive.tar 

curl命令非常強大,可以通過man curl了解更多它的功能 。

8. 最有效的利用正則表達(dá)式

大量 UNIX 命令使用正則表達(dá)式作為參數(shù)。從技術(shù)角度而言,正則表達(dá)式是表示某種模式的字符串(也就是說,由字母、數(shù)字和符號組成的字符序列),用于定義零或更長的字符串。正則表達(dá)式使用元字符(例如,星號 [*] 和問號 [?])來匹配其他字符串的部分或全部內(nèi)容。正則表達(dá)式不一定包含通配符,但通配符可以使正則表達(dá)式在搜索模式和處理文件時發(fā)揮更大的作用。表 1 顯示了一些基本正則表達(dá)式序列。

表 1. 正則表達(dá)式序列

序列 說明

脫字符 (^) 匹配出現(xiàn)在行首的表達(dá)式,例如 ^A

美元符號 ($) 匹配出現(xiàn)在行末的表達(dá)式,例如 A$

反斜杠 (\) 取消下一個字符的特殊含義,例如 \^

方括號 ([]) 匹配括起來的任一字符,例如 [aeiou](使用連字符 [-] 表示范圍,例如 [0-9])。

[^ ] 匹配除括起來字符以外的任一字符,例如 [^0-9]

句點 (.) 匹配除行尾之外的任意單個字符

星號 (*) 匹配零個或多個前驅(qū)字符或表達(dá)式

\{x,y\} 匹配出現(xiàn)過 x 到 y 個和前面相同的內(nèi)容

\{x\} 精確匹配出現(xiàn)過 x 個和前面相同的內(nèi)容

\{x,\} 匹配出現(xiàn)過 x 個或更多和前面相同的內(nèi)容

以下是經(jīng)常與 grep 命令一起使用的一些基本正則表達(dá)式:

List11:使用正則表達(dá)式和 grep

 

  1. $ # Lists your mail 
  2.  
  3. $ grep '^From: ' /usr/mail/$USER    
  4.  
  5. $ # Any line with at least one letter   
  6.  
  7. $ grep '[a-zA-Z]'  search-file.txt 
  8.  
  9. $ # Anything not a letter or number 
  10.  
  11. $ grep '[^a-zA-Z0-9] search-file.txt 
  12.  
  13. $ # Find phone numbers in the form 999-9999  
  14.  
  15. $ grep '[0-9]\{3\}-[0-9]\{4\}' search-file.txt 
  16.  
  17. $ # Find lines with exactly one character 
  18.  
  19. $ grep '^.$' search-file.txt 
  20.  
  21. $ #  Find any line that starts with a period "."           
  22.  
  23. $ grep '^\.' search-file.txt  
  24.  
  25. $ # Find lines that  start with a "." and 2 lowercase letters 
  26.  
  27. $ grep '^\.[a-z][a-z]' search-file.txt 

9. 確定當(dāng)前用戶

有時查找問題是,需要確定某個特定用戶是否運行過您的管理腳本。為找出答案,您可以使用 whoami 命令來返回當(dāng)前用戶的名稱:

List12:從命令行使用 whoami

  1. $ whoami 
  2.  
  3. John  

List13:用 whoami 確保當(dāng)前用戶不是根用戶的 Bash 腳本

 

  1. if [ $(whoami) = "root" ] 
  2.  
  3. then 
  4.  
  5.    echo "You cannot run this script as root." 
  6.  
  7.    exit 1 
  8.  
  9. fi 

10. 用awk處理數(shù)據(jù)

awk 命令似乎始終處在 Perl 的陰影下,但它對于簡單、基于命令行的數(shù)據(jù)處理來說是一個快速、實用的工具。List 14 展示了如何開始使用 awk 命令。

若要獲取文件中每行文本的長度,用 length() 函數(shù)。若要查看字符串 ing 是否出現(xiàn)在文件文本中,請用 index() 函數(shù),該函數(shù)返回 ing ***出現(xiàn)的位置,這樣您就可以使用它來進(jìn)行進(jìn)一步的字符串處理。若要 tokenize(也就是說,將一行拆分為單詞長度的片段)某個字符串,請使用 split() 函數(shù)。

List14:基本awk處理

  1. $ cat text 
  2.  
  3. testing the awk command 
  4.  
  5. $ awk '{ i = length($0); print i }' text 
  6.  
  7. 23 
  8.  
  9. $ awk '{ i = index($0,”ing”); print i}' text 
  10.  
  11.  
  12. $ awk 'BEGIN { i = 1 } { n = split($0,a," "); while (i <= n) {print a[i]; i++;} }' text 
  13.  
  14. testing  
  15.  
  16. the 
  17.  
  18. awk 
  19.  
  20. command 

打印文本文件中的指定字段是一項簡單的 awk 任務(wù)。在List 15中,sales 文件包含每個銷售人員的姓名,后跟每月銷售數(shù)字??梢允褂?awk 命令來快速獲得每個月的銷售總額。缺省情況下,awk 將每個以逗號分隔的值視為不同的字段。用 $n 操作符來訪問每個字段。

List15:用awk對數(shù)據(jù)進(jìn)行匯總

 

  1. $cat sales 
  2.  
  3. Gene,12,23,7 
  4.  
  5. Dawn,10,25,15 
  6.  
  7. Renee,15,13,18 
  8.  
  9. David,8,21,17 
  10.  
  11. $ awk -F, '{print $1,$2+$3+$4}' sales 
  12.  
  13. Gene 42 
  14.  
  15. Dawn 50 
  16.  
  17. Renee 46 
  18.  
  19. David 46  

 

責(zé)任編輯:龐桂玉 來源: 程序猿
相關(guān)推薦

2010-03-15 09:40:19

Windows 8研發(fā)

2015-05-27 14:38:14

戴爾云計算

2009-03-31 11:12:59

萬兆以太網(wǎng)

2020-09-22 10:49:12

大數(shù)據(jù)旅游技術(shù)

2015-07-03 11:07:34

程序猿作法

2014-11-28 13:37:30

DCN無線

2021-04-27 11:20:20

機(jī)器學(xué)習(xí)骨科醫(yī)療

2021-11-11 11:05:35

CSS游戲前端

2021-10-20 10:03:52

網(wǎng)絡(luò)

2023-04-12 16:12:09

2020-07-05 07:56:58

Python語言開發(fā)

2016-09-07 15:38:13

綠色數(shù)據(jù)中心能源消耗

2014-11-13 15:54:23

Imperva亞馬遜

2021-01-29 17:57:32

存儲

2020-09-10 09:44:35

JavaScript

2022-07-27 22:15:20

HarmonyOS鴻蒙鴻蒙系統(tǒng)

2011-09-16 11:38:34

AVGQQ電腦管家

2023-12-18 13:06:25

腦機(jī)接口AI
點贊
收藏

51CTO技術(shù)棧公眾號