• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Prayer

            在一般中尋求卓越
            posts - 1256, comments - 190, trackbacks - 0, articles - 0
              C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            shell學(xué)習(xí)之-sed用法解析

            Posted on 2009-08-30 23:15 Prayer 閱讀(5442) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): Shell

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

            命令行概述:
                sed 編輯指令的格式如下 :
                          [address1[,address2]]function[argument]
            其中 , 位址參數(shù) address1 、address2 為行數(shù)或 regular expression 字串 , 表示所執(zhí)行編輯的資料行; 函數(shù)參數(shù) function[argument] 為 sed 的內(nèi)定函數(shù) , 表示執(zhí)行的編輯動(dòng)作。

            有那些函數(shù)(function)參數(shù)
               下頁(yè)表中介紹所有 sed 的函數(shù)參數(shù)(參照[chapter 4])的功能。
            函數(shù)參數(shù) 功能
            : label  建立 script file 內(nèi)指令互相參考的位置。
            #  建立解
            { }  集合有相同位址參數(shù)的指令。
            !  不執(zhí)行函數(shù)參數(shù)。
            =  印出資料行數(shù)( line number )。
            a\  添加使用者輸入的資料。
            b label  將執(zhí)行的指令跳至由 : 建立的參考位置。
            c\  以使用者輸入的資料取代資料。
            d  刪除資料。
            D  刪除 pattern space 內(nèi)第一個(gè) newline 字母 \ 前的資料。
            g  拷貝資料從 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 內(nèi)第一個(gè) newline 字母 \ 前的資料。
            q  跳出 sed 編輯。
            r  讀入它檔內(nèi)容。
            s  替換字串。
            t label  先執(zhí)行一替換的編輯指令 , 如果替換成牛p>則將編輯指令跳至 : label 處執(zhí)行。
            w  寫(xiě)資料到它檔內(nèi)。
            x  交換 hold space 與 pattern space 內(nèi)容。
            y  轉(zhuǎn)換(transform)字元。
            雖然 , sed 只有上表所述幾個(gè)擁有基本編輯功能的函數(shù) , 但由指令中位址參數(shù)和指令與指令間的配合 , 也能使sed 完成大部份的編輯任務(wù)。

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

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

            (3) sed -e '/#/d' file  (刪除含有'#'號(hào)的行)
                思考:刪除含有字母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行

            (5) sed -e '/t.*t/d' file     (刪除含有兩個(gè)t的行)
                思考:刪除含有指定正在表達(dá)式匹配的行。


            2.2 替換      
            Sed 可替換文件中的字串、資料行、甚至資料區(qū)。其中,表示替換字串的指令中的函數(shù)參數(shù)為s;表示替換資料行、或資料區(qū)>的指令中的函數(shù)參數(shù)為c。上述情況以下面三個(gè)例子說(shuō)明。

            *行的替換
            (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參數(shù)最多與兩個(gè)位置參數(shù)相結(jié)合,函數(shù)參數(shù)s中有兩個(gè)特殊的符號(hào):
                & : 代表pattern
                \n : 代表 pattern 中被第 n 個(gè) \( 、\)(參照[附錄 A]) 所括起來(lái)的字串。例如

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

            *flag 參數(shù)舉例
                sed -e 's/w1/& w2/g' file
                g : 代表替換所有匹配項(xiàng)目;這里,文件中所有字符串w1都會(huì)被替換成字串w1 w2
                sed -e 's/w1/& w2/10' file
                m(10) : 替換行內(nèi)第m個(gè)符合的字串; 記住,是行內(nèi)的第m個(gè)匹配的字串
                sed -e 's/w1/& w2/p' file
                p : 替換第一個(gè)和w1匹配的字符串為w1 w2,并輸出到標(biāo)準(zhǔn)輸出.
                sed -e 's/w1/& w2/w w2file' file
                w filename : 該參數(shù)會(huì)將替換過(guò)的內(nèi)容寫(xiě)入到文件w2file并輸出替換后的整個(gè)文件。注意w2file里寫(xiě)的只是替換過(guò)的行。    sed 'e 's/w1/& w2/' file
                這里的flag 為空, 這樣就只是將第一個(gè)w1匹配的字符串替換成w1 w2而后面的不進(jìn)行替換。

            *位置參數(shù)應(yīng)用舉例
                sed -e '/machine/s/phi/beta/g' file
                將文件中含"machine"字串的資料行中的"phi"字串,替換成為"beta"字串
                sed -e '1,10 s/w1/& w2/g' file
                把1到10內(nèi)的w1字符串替換成w1 w2字符串。
                sed -e '1,/else/ s/w1/& w2/g' file
                把1到字符串else內(nèi)的w1字符串替換成w1 w2字符串。

            其它位置參數(shù)的應(yīng)用與前面的相同。


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

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

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

            a
                a參數(shù)的使用格式如下:
                [address] a\ <插入內(nèi)容> filename

                sed -e '/unix/a\ haha' test.txt   #在含有unix的行后添加"haha"
                #輸出結(jié)果為:
                    unix
                    haha

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

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

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

                p函數(shù)為sed的打印函數(shù),在這里要注意-e 和-n 參數(shù)的區(qū)別。一般使用-n參數(shù)。


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

            2.6 反相執(zhí)行命令 : !
                基本格式:
                [address1[ , address2]] ! 函數(shù)參數(shù)

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


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

                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
                輸出文中的偶數(shù)行

            3, 命令的復(fù)用
                一次執(zhí)行多個(gè)命令的方式有三種:
                (1) sed 's/w1/& w2/g; 1/i\words' filename   (使用;號(hào)把命令隔開(kāi),注意前面不加-e參數(shù))
                (2) sed -e 'cmd1' -e 'cmd2'  filename     (使用多個(gè)-e參數(shù))

            本文來(lái)自CSDN博客,轉(zhuǎn)載請(qǐng)標(biāo)明出處:http://blog.csdn.net/zg_hover/archive/2007/09/28/1804481.aspx

            精品乱码久久久久久久| 久久精品一区二区影院| AAA级久久久精品无码片| 久久亚洲国产午夜精品理论片| 精品久久久久久无码中文野结衣| 人人狠狠综合久久亚洲| 久久精品天天中文字幕人妻 | 一本色综合久久| 久久99精品国产麻豆| 午夜精品久久久久久影视riav| 久久人人爽人人爽人人AV东京热| 韩国三级中文字幕hd久久精品 | 一本久道久久综合狠狠爱| 亚洲国产精品久久久久| 国内精品伊人久久久久777| 韩国三级中文字幕hd久久精品| 无码专区久久综合久中文字幕 | 色欲综合久久躁天天躁| 99久久国语露脸精品国产| 久久久久久久97| 伊人久久五月天| 久久精品夜色噜噜亚洲A∨| 热99re久久国超精品首页| 久久久久久亚洲精品成人| 久久人人爽人人爽人人片AV不 | 久久久黄片| 精品久久久久久无码国产| 99国产精品久久| 国产产无码乱码精品久久鸭| 午夜人妻久久久久久久久| 99久久免费国产精品特黄| 久久久久久噜噜精品免费直播| 伊人丁香狠狠色综合久久| 91精品婷婷国产综合久久| 免费观看成人久久网免费观看| 久久狠狠色狠狠色综合| 26uuu久久五月天| 国产午夜精品理论片久久| 国产L精品国产亚洲区久久| 欧美久久精品一级c片片| 亚洲国产精久久久久久久|