shell: sed使用方法

sed介紹

http://blog.csdn.net/zhlccna/article/details/6757740

    sed可刪除(delete)、改變(change)、添加(append)、插入(insert)、合、交換文件中的資料行,或讀入其它檔的資料到文>件中,也可替換(substuite)它們其中的字串、或轉換(tranfer)其中的字母等等。例如將文件中的連續空白行刪成一行、"local"字串替換成"remote"、"t"字母轉換成"T"、將第10行資料與第11資料合等.
    總合上述所言,當sed由標準輸入讀入一行資料並放入pattern space時,sed依照sed script 的編輯指令逐一對pattern space內的資料執行編輯,之後,再由pattern space內的結果送到標準輸出,接着再將下一行資料讀入.如此重執行上述動作,直至讀>完所有資料行爲止.
    小結,記住:
            (1)sed總是以行對輸入進行處理
            (2)sed處理的不是原文件而是原文件的拷貝

命令行概述:
    sed 編輯指令的格式如下 :
              [address1[,address2]]function[argument]
其中 , 位址參數 address1 、address2 爲行數或 regular expression 字串 , 表示所執行編輯的資料行; 函數參數 function[argument] 爲 sed 的內定函數 , 表示執行的編輯動作。

有那些函數(function)參數
   下頁表中介紹所有 sed 的函數參數(參照[chapter 4])的功能。
函數參數 功能
: label    建立 script file 內指令互相參考的位置。
#             建立解
{ }           集合有相同位址參數的指令。
            不執行函數參數。
=            印出資料行數( line number )。
a\          添加使用者輸入的資料。
b label  將執行的指令跳至由 : 建立的參考位置。
c\           以使用者輸入的資料取代資料。
d            刪除資料。
D           刪除 pattern space 內第一個 newline 字母 \ 前的資料。
          拷貝資料從 hold space。
G          添加資料從 hold space 至 pattern space 。
h           拷貝資料從 pattern space 至 hold space 。
H          添加資料從 pattern space 至 hold space 。
l            印出 l 資料中的 nonprinting character 用 ASCII 碼。
i\           插入添加使用者輸入的資料行。
n           讀入下一筆資料。
N          添下一筆資料到 pattern space。
p          印出資料。
P          印出 pattern space 內第一個 newline 字母 \ 前的資料。
q          跳出 sed 編輯。

r           讀入它檔內容。

s            替換字串。

t              label  先執行一替換的編輯指令 , 如果替換成牛p>則將編輯指令跳至 : label 處執行。
w           寫資料到它檔內。
x            交換 hold space 與 pattern space 內容。
y             轉換(transform)字元。
雖然 , sed 只有上表所述幾個擁有基本編輯功能的函數 , 但由指令中位址參數和指令與指令間的配合 , 也能使sed 完成大部份的編輯任務。

2,1 刪除
(1) sed -e '1d' inputfile (刪除第一行)
    那麼刪除第x行呢?刪除第x1,x2,x3行呢?
    sed -e 'xd' inputfile
    sed -e 'x1d' -e 'x2d' -e 'x3d' inputfile
    當然也許還有更好的辦法。

(2) sed -e '1,3d' file (刪除第一到第三行)
    思考:刪除第n行到第m行?也就是
    sed -e 'n,md' file
    刪除第一行到最後一行
 
  #$ 最後一行和一行的最後

(3) sed -e '/#/d' file  (刪除含有'#'號的行)
    思考:刪除含有字母xx的行
    sed -e '/xx/d' file
    思考: 刪除除含有字符串xx的所有行
    sed -e '/xx/!d' file

(4) sed -e '/word1/, /word2/d' file  (刪除從含有單詞word1到含有單詞word2的行)
    sed -e '10,/word1/d' file
    刪除文件中從第10行到含有word1的行
    sed -e '/word1/,10/d' file
    和上面的匹配相反,刪除從含有word1的行到第10行
    sed -e '/\[14:26:34\]/,$d' -i TRACE20110813 
刪除從匹配的到字符到最後一行。
(5) sed -e '/t.*t/d' file     (刪除含有兩個t的行)
    思考:刪除含有指定正在表達式匹配的行。

2.2 替換       
Sed 可替換文件中的字串、資料行、甚至資料區。其中,表示替換字串的指令中的函數參數爲s;表示替換資料行、或資料區>的指令中的函數參數爲c。上述情況以下面三個例子說明。

*行的替換
(1) sed -e '1c\#!/bin/more' file (把第一行替換成#!/bin/more)
    思考: 把第n行替換成just do it
    sed -e 'nc\just do it' file

(2) sed -e '1,10c\I can do it' file  (把1到10行替換成一行:I can do it)
    思考: 換成兩行(I can do it! Let's start)
    sed -e '1,10c\I can do it!\nLet'"\'"'s start' file

*字符的替換
(3) sed -e 's/word1/& word2/' file (將每一行的word1單詞替換成s參數最多與兩個位置參數相結合,函數參數s中有兩個特殊的符號:
    & : 代表pattern
    \n : 代表 pattern 中被第 n 個 \( 、\)(參照[附錄 A]) 所括起來的字串。例如

    sed -e 's/w1/& w2/' file  # w1的地方輸出 w1 w2
    sed -e  's/\(test\) \(my\) \(car\)/[\2 \3 \1]/' file   #結果: [my car test]

*flag 參數舉例
    sed -e 's/w1/& w2/g' file
    g : 代表替換所有匹配項目;這裏,文件中所有字符串w1都會被替換成字串w1 w2
    sed -e 's/w1/& w2/10' file
    m(10) : 替換行內第m個符合的字串; 記住,是行內的第m個匹配的字串
    sed -e 's/w1/& w2/p' file
    p : 替換第一個和w1匹配的字符串爲w1 w2,並輸出到標準輸出.
    sed -e 's/w1/& w2/w w2file' file
    w filename : 該參數會將替換過的內容寫入到文件w2file並輸出替換後的整個文件。注意w2file裏寫的只是替換過的行。    sed 'e 's/w1/& w2/' file
    這裏的flag 爲空, 這樣就只是將第一個w1匹配的字符串替換成w1 w2而後面的不進行替換。

*位置參數應用舉例
    sed -e '/machine/s/phi/beta/g' file
    將文件中含"machine"字串的資料行中的"phi"字串,替換成爲"beta"字串
    sed -e '1,10 s/w1/& w2/g' file
    把1到10內的w1字符串替換成w1 w2字符串。
    sed -e '1,/else/ s/w1/& w2/g' file
    把1到字符串else內的w1字符串替換成w1 w2字符串。

其它位置參數的應用與前面的相同。

2.3 內容的插入
i
    基本格式:
    [address] i\ 插入內容 filename
 word2)
說明:
函數參數 s 表示替換(substitute)文件內字串。其指令格式如下 :
[address1[ ,address2]] s/pattern/replacemen/[flag]

    sed -e '/#/i\words' file      #在#字符的前面插入一行words

說明:
    這裏的函數參數是i,它只能有一個地址參數。
    sed -e '1/i\words' file
    在第一行前加一行words
    cat "word" | sed -e '/$/.doc/g'   #輸出word.doc
    在word後面加上後綴名,從而輸出word.doc
    i 參數正好與a參數相反,它是插入到所給內容的前面.

a
    a參數的使用格式如下:
    [address] a\ <插入內容> filename

    sed -e '/unix/a\ haha' test.txt   #在含有unix的行後添加"haha"
    #輸出結果爲:
        unix
        haha

    另外: sed -e '1 a\ hh' test.txt  #在第一行後添加hh字符.

2.4 文本的打印: p
    基本格式:
    [address1,[address2]] p

    (1) sed -e '/then/ p' filename  #打印所有行並重復打印含有then 的行
    (2) sed -n '/then/ p' filename  #只打印含有then的行
    (3) sed -e '1,3 p' filename     # 打印所有行並重復1-3行
    (4) sed -n '1,3 p' filename     # 打印1-3行
    (5) sed -n '/if/,/fi/ p' filename #打印字符if和fi之間的內容

    p函數爲sed的打印函數,在這裏要注意-e 和-n 參數的區別。一般使用-n參數。


2.5 字元的替換: y
    例如:
    (1)sed -e 'y/abc../xyz../' filename
    把文件中的a字母替換成x, b替換成y, c替換成z。
    (2) sed  -e 'y/abc/ABC' filename
    把小寫的abc轉換成大寫的ABC

2.6 反相執行命令 : !
    基本格式:
    [address1[ , address2]] ! 函數參數

    sed -e '/1996/!d' filename
    刪除除了含有1996的所有行。

2.7 改變文件中的資料: c
    基本格式:
    [address1[ ,address2]]c\ filename
    函數參數 c 緊接着 "\" 字元用來表示此行結束 , 使用者所輸入的資料必須從下一行輸入。如果資料超過一行 , 則須在>每行的結尾加入"\"

    sed -e '/zhengxh/c hhhh' filename
    表示把含有字符串zhengxh的行,該成hhhh。

2.8 讀入下一行資料: n
    基本格式:
    [address1[ ,address2]] n

    sed -n -e '/echo/n' -e 'p' temp
    表示輸出文件,但如果一行含有字符串echo,則輸出包含該字符串的下一行。
    sed -n -e 'n' -e 'p' filename
    輸出文中的偶數行

3, 命令的複用
    一次執行多個命令的方式有三種:
    (1) sed 's/w1/& w2/g; 1/i\words' filename   (使用;號把命令隔開,注意前面不加-e參數)
    (2) sed -e 'cmd1' -e 'cmd2'  filename     (使用多個-e參數)   
Sed 可替換文件中的字串、資料行、甚至資料區。其中,表示替換字串的指令中的函數參數爲s;表示替換資料行、或資料區>的指令中的函數參數爲c。上述情況以下面三個例子說明。

*行的替換
(1) sed -e '1c\#!/bin/more' file (把第一行替換成#!/bin/more)
    思考: 把第n行替換成just do it
    sed -e 'nc\just do it' file

(2) sed -e '1,10c\I can do it' file  (把1到10行替換成一行:I can do it)
    思考: 換成兩行(I can do it! Let's start)
    sed -e '1,10c\I can do it!\nLet'"\'"'s start' file

*字符的替換
(3) sed -e 's/word1/& word2/' file (將每一行的word1單詞替換成s參數最多與兩個位置參數相結合,函數參數s中有兩個特殊的符號:
    & : 代表pattern
    \n : 代表 pattern 中被第 n 個 \( 、\)(參照[附錄 A]) 所括起來的字串。例如

    sed -e 's/w1/& w2/' file  # w1的地方輸出 w1 w2
    sed -e  's/\(test\) \(my\) \(car\)/[\2 \3 \1]/' file   #結果: [my car test]

*flag 參數舉例
    sed -e 's/w1/& w2/g' file
    g : 代表替換所有匹配項目;這裏,文件中所有字符串w1都會被替換成字串w1 w2
    sed -e 's/w1/& w2/10' file
    m(10) : 替換行內第m個符合的字串; 記住,是行內的第m個匹配的字串
    sed -e 's/w1/& w2/p' file
    p : 替換第一個和w1匹配的字符串爲w1 w2,並輸出到標準輸出.
    sed -e 's/w1/& w2/w w2file' file
    w filename : 該參數會將替換過的內容寫入到文件w2file並輸出替換後的整個文件。注意w2file裏寫的只是替換過的行。    sed 'e 's/w1/& w2/' file
    這裏的flag 爲空, 這樣就只是將第一個w1匹配的字符串替換成w1 w2而後面的不進行替換。

*位置參數應用舉例
    sed -e '/machine/s/phi/beta/g' file
    將文件中含"machine"字串的資料行中的"phi"字串,替換成爲"beta"字串
    sed -e '1,10 s/w1/& w2/g' file
    把1到10內的w1字符串替換成w1 w2字符串。
    sed -e '1,/else/ s/w1/& w2/g' file
    把1到字符串else內的w1字符串替換成w1 w2字符串。

其它位置參數的應用與前面的相同。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章