歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux基礎 >> Linux技術 >> 在Linux上使用GNU sed的方法

在Linux上使用GNU sed的方法

日期:2017/3/1 17:25:41   编辑:Linux技術

Linux 基金會宣布了一個全新的 LFCS(Linux 基金會認證系統管理員(Linux Foundation Certified Sysadmin))認證計劃。這一計劃旨在幫助遍布全世界的人們獲得其在處理 Linux 系統管理任務上能力的認證。這些能力包括支持運行的系統服務,以及第一手的故障診斷、分析,以及為工程師團隊在升級時提供明智的決策。

在Linux上使用GNU sed的方法

處理 Linux 中的文本流

Linux 將程序中的輸入和輸出當成字符流或者字符序列。在開始理解重定向和管道之前,我們必須先了解三種最重要的I/O(輸入和輸出(Input and Output))流,事實上,它們都是特殊的文件(根據 UNIX 和 Linux 中的約定,數據流和外圍設備(設備文件)也被視為普通文件)。

在 > (重定向操作符) 和 | (管道操作符)之間的區別是:前者將命令與文件相連接,而後者將命令的輸出和另一個命令相連接。

# command >file

# command1 | command2

由於重定向操作符會靜默地創建或覆蓋文件,我們必須特別小心謹慎地使用它,並且永遠不要把它和管道混淆起來。在 Linux 和 UNIX 系統上管道的優勢是:第一個命令的輸出不會寫入一個文件而是直接被第二個命令讀取。

在下面的操作練習中,我們將會使用這首詩——《A happy child》(作者未知)

在Linux上使用GNU sed的方法

使用 sed

sed 是流編輯器(stream editor)的縮寫。為那些不懂術語的人額外解釋一下,流編輯器是用來在一個輸入流(文件或者管道中的輸入)執行基本的文本轉換的工具。

sed 最基本的用法是字符替換。我們將通過把每個出現的小寫 y 改寫為大寫 Y 並且將輸出重定向到 ahappychild2.txt 開始。g 標志表示 sed 應該替換文件每一行中所有應當替換的實例。如果這個標志省略了,sed 將會只替換每一行中第一次出現的實例

基本語法:

#sed's/term/replacement/flag'file

我們的樣例:

#sed's/y/Y/g' ahappychild.txt > ahappychild2.txt

在Linux上使用GNU sed的方法

如果你要在替換文本中搜索或者替換特殊字符(如 /,\,&),你需要使用反斜槓對它進行轉義。

例如,我們要用一個符號來替換一個文字,與此同時我們將把一行最開始出現的第一個 I 替換為 You。

#sed's/and/\&/g;s/^I/You/g' ahappychild.txt

在Linux上使用GNU sed的方法

在上面的命令中,眾所周知 ^(插入符號)是正則表達式中用來表示一行開頭的符號。

正如你所看到的,我們可以通過使用分號分隔以及用括號包裹來把兩個或者更多的替換命令(並在它們中使用正則表達式)連接起來。

另一種 sed 的用法是顯示或者刪除文件中選中的一部分。在下面的樣例中,將會顯示 /var/log/messages 中從6月8日開始的頭五行。

#sed-n '/^Jun 8/ p'/var/log/messages |sed-n 1,5p

請注意,在默認的情況下,sed 會打印每一行。我們可以使用 -n 選項來覆蓋這一行為並且告訴 sed 只需要打印(用 p來表示)文件(或管道)中匹配的部分(第一個命令中指定以“Jun 8” 開頭的行,第二個命令中指定一到五行)。

最後,可能有用的技巧是當檢查腳本或者配置文件的時候可以保留文件本身並且刪除注釋。下面的單行 sed 命令刪除(d)空行或者是開頭為#的行(| 字符對兩個正則表達式進行布爾 OR 操作)。

#sed'/^#\|^$/d' apache2.conf

在Linux上使用GNU sed的方法

uniq 命令

uniq 命令允許我們返回或者刪除文件中重復的行,默認寫到標准輸出。我們必須注意到,除非兩個重復的行相鄰,否則uniq 命令不會刪除他們。因此,uniq 經常和一個前置的 sort 命令(一種用來對文本行進行排序的算法)搭配使用。默認情況下,sort 使用第一個字段(用空格分隔)作為關鍵字段。要指定一個不同的關鍵字段,我們需要使用 -k 選項。

樣例

du –sch /path/to/directory/* 命令將會以人類可讀的格式返回在指定目錄下每一個子文件夾和文件的磁盤空間使用情況(也會顯示每個目錄總體的情況),而且不是按照大小輸出,而是按照子文件夾和文件的名稱。我們可以使用下面的命令來讓它通過大小排序。

#du-sch /var/* | sort -h

在Linux上使用GNU sed的方法

你可以通過使用下面的命令告訴 uniq 比較每一行的前6個字符(-w 6)(這裡是指定的日期)來統計日志事件的個數,而且在每一行的開頭輸出出現的次數(-c)。

#cat/var/log/mail.log |uniq-c -w6

在Linux上使用GNU sed的方法

上一頁12 下一頁 閱讀全文

Copyright © Linux教程網 All Rights Reserved