makefile(shell)中sed命令詳解

來源:互聯網
上載者:User

 

Sed(a stream editor)

4 個空間 :input stream, pattern buffer, output stream 和 hold buffer
基本操作過程是 :
(1). 將 input stream 的當前行放入 pattern buffer, 然後 input stream 的指標指向下一行 ;
(2). 對 pattern buffer 中的行進行處理 ;
(3). 將 2 的處理結果放入 output stream. 然後迴圈這個過程 .

hold buffer 是另一個空間 , 可以通過命令和 pattern buffer 進行互動 . 

sed 命令介紹 

1. 基本命令 ---" 替換 ": s

www.ixdba.net

  1.1 基本用法 
  e.g. sed 's/day/night/' <old >new
  該例子將檔案 old 中的每一行第一次出現的 day 替換成 night, 將結果輸出到檔案 new
  s            " 替換 " 命令 
  /../../      分割符 (Delimiter)
  day          搜尋字串 
  night        替換字串 

  其實 , 分割符 "/" 可以用別的符號代替 , 比如 ",", "|" 等 .
  e.g. sed 's///usr//local//bin///common//bin/'<old >new
  等價於 sed 's_/usr/local/bin_/common/bin_' <old >new
  顯然 , 此時用 "_" 作分割符比 "/" 好得多 .

  1.2 用 & 表示匹配的字串 

  有時可能會想在匹配到的字串周圍或附近加上一些字元 .
  e.g. sed 's/abc/(abc)/' <old >new
  該例子在找到的 abc 前後加上括弧 .
  該例子還可以寫成 sed 's/abc/(&)/' <old >new
  下面是更複雜的例子 :
  sed 's/[a-z]*/(&)/' <old >new
  sed 's/[0-9]*/& &/' <old >new

  1.3 用 /1, /2, ..., /9 來表示匹配的字串 

  e.g. sed 's//([a-z]*/)[0-9]*//1/' <old >new
  本例中 /1 就是指前面的 /([a-z]*/)

  sed 's//([a-z]*/) /([0-9]*/)//2 /1/' <old >new
  本例中 /2 和 /1 分別代表前面的 /([0-9]*/) 和 /([a-z]*/)

  /1, /2, ..., /9 也可以出現在搜尋字串中 
  e.g. sed 's//([a-z]*/) /1//1/' <old >new
  本例可以去除重複的由字母組成的詞 

  1.4 " 替換 " 選項 
      1.4.1 /g 替換所有的 
      sed 預設只替換搜尋字串的第一次出現 , 利用 /g 可以替換搜尋字串所有 
      出現的地方 . 例如 ,
      sed 's//([^ ]*/)/(&)/g' <old >new

      1.4.2 用 /1, /2, ... 來表明替換哪一次出現 
      e.g. sed 's/[^ ]*//2' <old >new
      可以從 /1 用到 /512

      1.4.3 /p print 選項 
      當 sed 命令有 -n 選項時 , 該命令沒用輸出 .
      -n 配合 /p 選項後 , 如果該行確實發生了替換 , 則輸出該行 , 否則不輸出 .

      1.4.4 /w filename 寫到檔案 filename 中 
      e.g. sed 's//([0-9]*/) /([a-z]*/)//2/w new' <old
      該例子把輸出放入檔案 new 中 

  1.5 替換和插入分行符號號 
  替換 (echo a;echo x;echo y) | sed '/x$/ {
       N
       s:x/n:x:
       }'

  插入 
       (echo a;echo x;echo y) | sed 's:x:X/
       :'

2. 只對特定行的處理 

  2.1 通過行號限定 
  sed '3 s/[0-9][0-9]*//' <old >new 只處理第 3 行 

  sed '1,100 s/A/a/' <old >new 只處理 1 到 100 行 

  sed '101,$ s/A/a/' <old >new 處理 101 到檔案的最後一行 

  sed '101,$ !s/A/a/' <old >new 這裡 ! 表示只對 1 到 100 行進行替換 ,! 的作用 是取反 

  2.2 通過正規運算式限定 
  sed '/start/,/stop/ s/#.*//' <old >new
  本例中 ,sed 先找到有 start 的行作為開始 , 找到最近的有 stop 的行作為結束 , 對之 
  間的行進行操作 .
  重複上述過程 , 直到檔案結束 

  下面這個例子是行號和正規運算式配合來限定 
  sed '1,/start/ s/#.*//' <old >new 對第 1 行到含有 start 的行進行處理 

3. 其他的簡單命令 
  3.1 刪除命令 d
  sed '11,$ d' <old >new 刪除從 11 行到檔案末尾 
  sed '/^#/ d' <old >new 刪除所有以 # 開始的行 

  3.2 print 命令 p ( 注意 與 s 命令的 /p 選項的區別 )
  sed 'p' <old    每一行將會被輸出兩次 
  sed -n 'p' <old 每一行將會輸出一次 (-n 屏蔽掉一次 )
  sed '/^$/ p' <old 只對空行輸出兩次 , 其他只輸出一次 
  sed -n '1,10 p' <old 輸出前 10 行 
  sed -n '/match/ p' <old 輸出含有 match 的行 

  3.3 quit 命令 q
  sed '11 q'<old    輸出前 10 行 ( 在第 11 行退出 )
  注意 :q 命令不能接收多行 , 例如 
  sed '2,5 q'<old 是不正確的 

  3.4 寫入檔案命令 w filename( 注意與 s 命令的 /w 選項的區別 )
  把某些行寫入檔案 filename
  sed -n '/^[0-9]*[02468]/ w even' <old    將以偶數開始的行寫入檔案 even

  3.5 輸出行號命令 =
  sed -n '/PATTERN/ =' <old 遇到含有 PATTERN 的行時 , 同時輸出行號 

  3.6 追加 , 改變 , 插入新行 
  追加命令 a
  #!/bin/sh
  sed '
  /WORD/ a/
  Add this line after every line with WORD
  '

  改變命令 c
  #!/bin/sh
  sed '
  /WORD/ c/
  Replace the current line with the line
  '

  插入命令 i
  #!/bin/sh
  sed '
  /WORD/ i/
  Add this line before every line with WORD
  '

  3.7 變換命令 y
  sed 'y/abcdef/ABCDEF/' <old  該例將字元 abcdef 分別變成大寫 

  3.8 將本行的控制符也顯示出來的命令 l
  sed '1,10 l' <old

  3.9 d 命令和 D 命令 
  d 命令刪除 pattern buffer 中的內容進入下一次操作迴圈 
  D 命令刪除 pattern buffer 中第一個分行符號之前的內容進入下一次操作迴圈 , 如 
  果 pattern buffer 中還有內容 , 則不用從 input stream 中讀入 

  3.10 p 命令和 P 命令 
  p 命令輸出 pattern buffer 中的內容 
  P 命令輸出 pattern buffer 中第一個分行符號之前的內容 

  3.11 n 命令和 N 命令 
  n 命令把下一行讀入 pattern buffer 中 ( 如果沒用 -n 選項 , 將原來行輸出 )
  N 命令把下一行追加到 pattern buffer 中 

 3.12 流程式控制制命令 
  b label 命令 : 在指定行跳到 label
  t label 命令 : 如果在某行發生了替換 , 跳到 label
  T label 命令 : 如果在某行沒有發生了替換 , 跳到 label

4. 調用 sed 時的參數 

  4.1 -e script 執行 script 這個指令碼 
  e.g. sed -e 's/a/A/' -e 's/b/B/' <old >new
  對每一行分別執行 's/a/A/' 和 's/b/B/'

  4.2 -n     禁止輸出 
  這裡的 -n 與前面的 /p 配合 , 可以只輸出被修改了的行 .

  4.3 -f scriptname 把 scriptname 檔案中的 sed 命令加入本次 sed 的調用中 
  e.g. sed -f sedscript <old >new

  sedscript 的內容可能是這樣的 :
  # sed comment - This script changes lower case vowels to upper case
  s/a/A/g
  s/e/E/g
  s/i/I/g
  s/o/O/g
  s/u/U/g

5. Hold Buffer 

  x 命令 : 將 pattern buffer 放入 hold buffer, 而將 hold buffer 的內容輸出 ,pattern
  buffer 的內容變成下一行 
  h 命令 : 將 pattern buffer 放入 hold buffer, 並將 pattern buffer 的內容輸出 ,
  pattern buffer 的內容變成下一行 
  H 命令 : 將 pattern buffer 追加到 hold buffer
  g 和 G 命令 :g 用 hold buffer 的內容替換 pattern buffer 的內容 , 而 G 將 hold buffer 內 
  容追加到 pattern buffer

轉自也是轉載的部落格:http://blog.csdn.net/hoyi_liu/article/details/4251648

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.