文本處理三劍客之一的sed

處理文本的工具sed

  • Stream EDitor, 行編輯器

  • sed是一種流編輯器,它一次處理一行內容。處理時,把當前處理的行存儲在臨時緩沖區中,稱為“模式空間”(pattern space),接著用sed命令處理緩沖區中的內容,處理完成后,把緩沖區的內容送往屏幕。接著處理下一行,這樣不斷重復,直到文件末尾。文件內容并沒有改變,除非你使用重定向存儲輸出。Sed主要用來自動編輯一個或多個文件,簡化對文件的反復操作,編寫轉換程序等

  • 用法

    • sed[option]… ‘script’ inputfile…
  • 常用選項

    • -n:不輸出模式空間內容到屏幕,即不自動打印
    • -e: 多點編輯
    • -f:/PATH/SCRIPT_FILE: 從指定文件中讀取編輯腳本
    • -r: 支持使用擴展正則表達式
    • -i.bak: 備份文件并原處編輯
  • 地址定界

    • (1) 不給地址:對全文進行處理
    • (2) 單地址:

      • #: 指定的行
      • /pattern/:被此處模式所能夠匹配到的每一行
    • (3) 地址范圍:

      • #,#
      • #,+#
      • /pat1/,/pat2/
      • #,/pat1/
    • (4) ~:步進

      • 1~2 奇數行
      • 2~2 偶數行
  • 編輯命令

    • d: 刪除模式空間匹配的行
    • p: 顯示模式空間中的內容
    • a []text:在指定行后面追加文本,支持使用\n實現多行追加
    • i[]text:在行前面插入文本
    • c []text:替換行為單行或多行文本
    • w /path/somefile: 保存模式匹配的行至指定文件
    • r /path/somefile:讀取指定文件的文本至模式空間中匹配到的行后
    • =: 為模式空間中的行打印行號
    • !:模式空間中匹配行取反處理
    • s///:查找替換,支持使用其它分隔符,s@@@,s###

      • 替換標記

        • g: 行內全局替換
        • p: 顯示替換成功的行
        • w /PATH/TO/SOMEFILE:將替換成功的行保存至文件中
  • 高級編輯命令:

    • h: 把模式空間中的內容覆蓋至保持空間中
    • H:把模式空間中的內容追加至保持空間中
    • g: 從保持空間取出數據覆蓋至模式空間
    • G:從保持空間取出內容追加至模式空間
    • x: 把模式空間中的內容與保持空間中的內容進行互換
    • n: 讀取匹配到的行的下一行覆蓋至模式空間
    • N:讀取匹配到的行的下一行追加至模式空間
    • d: 刪除模式空間中的行
    • D:刪除當前模式空間開端至\n的內容(不再傳至標準輸出),放棄之后的命令,但是對剩余模式空間重新執行sed

sed示例

  • 取奇數行

    • seq 10|sed -n ‘1~2p’
    • seq 10|sed ‘2~2d’
    • seq 10 |sed -n ‘2~2!p’
    • seq 10 |sed ‘n;d’
  • 取偶數行

    • seq 10 |sed -n ‘n;p’
  • 取IP

    • ifconfig eth0|sed -n 2p|sed -e ‘s/.r://’ -e ‘s/ B.//’
    • ifconfig eth0|sed -e ‘s/.inet addr://’ -e ‘s/ B.//’ -n -e 2p
    • ifconfig eth0|sed ‘2!d;s/^.r://;s/ .//’
  • 取基名

    • echo /etc/sysconfig/network-scripts/ |sed -r ‘s@(/.*/)([/]+/?)@\2@’
  • 取目錄名

    • echo /etc/sysconfig/network-scripts/ |sed -r ‘s@(/.*/)([/]+/?)@\1@’
  • 對/etc/fstab非#開頭的加注釋

    • sed -r ‘s/([#])/#\1/’ /etc/fstab
    • sed -r ‘s/[#]/#&/’ /etc/fstab
  • 倒序顯示

    • seq 10 |sed ‘1!G;h;$!d’

原創文章,作者:XIAJIDONG,如若轉載,請注明出處:http://www.www58058.com/74346

(0)
XIAJIDONGXIAJIDONG
上一篇 2017-04-27
下一篇 2017-04-27

相關推薦

  • iptables基礎概念

    iptables基本概念梳理 前言 netfilter/Iptables (其中包括netfilter和Iptables兩個組件)組 成了Linux平臺下的包過濾防火墻,它與大多數的Linux自帶軟 件一樣,這個防火墻是免費提供的,它可以代替昂貴的企業級 防火墻來解決實際問題與實際方案,完成封包過濾,封包重定 向和網絡地址轉換等功能。 一、工作原理 數據包從…

    Linux干貨 2016-12-19
  • 初識mysql:基本原理和使用

    一、 數據庫的出現      1. 數據庫是什么: 數據庫簡單來說,就是存儲數據的地方(廢話),對于用戶認證這個過程來說,當用戶登錄服務器時, 系統需要把用戶的輸入的用戶認證信息和存儲的用戶認證信息進行比對,這一過程就需要事先把所有用戶的信息存儲在一個數據庫中,然后逐條進行比對。早起最傳統的數據庫當然就是文本…

    Linux干貨 2015-06-04
  • N28 第三周【1】:grep和文本處理工具的使用

    grep一些練習 1、列出當前系統上所有已經登錄的用戶的用戶名,注意:同一個用戶登錄多次,則只顯示一次即可。 [root@localhost ~]# who |cut -d” ” -f1 |sort -u root 2、取出最后登錄到當前系統的用戶的相關信息。 [root@localhost ~]# last |cut -d” ” -f1|head -1 |…

    Linux干貨 2017-12-19
  • DHCP使用幫助

    bootp 想要通過tcp/ip模型進行網絡通信需要有一個ip地址,IP地址是屬于操作系統的,所以沒有操作系統就沒有ip 為了解決這種問題,有一種網卡可以不需要操作系統就能獲取到ip bootp:只有第一次是動態獲得,以后ip地址就是和mac地址綁定的,不能分配給其他主機 DHCP:DHCP是bootp的改進版,主要引入了租約的定義 DHCP也可以根據mac…

    Linux干貨 2016-11-11
  • 第八周作業

    第八周作業 1、寫一個腳本,使用ping命令推測172.16.250.1-172.16.250.254之間的所有主機的在線狀態; 在線的主機使用綠色顯示; 不在線的主機使用紅色顯示;   #!/bin/bash for i in {1..254};do if ping -c 1 -w 1 192.168.1.$i &> /dev/nu…

    Linux干貨 2017-11-13
欧美性久久久久