一乐电子

 找回密码
 请使用微信账号登录和注册会员

QQ登录

只需一步,快速开始

微信扫码登录

搜索
查看: 4546|回复: 5

linux之sed用法

[复制链接]
发表于 2017-3-25 09:05 | 显示全部楼层 |阅读模式
sed是一个很好的文件处理工具,本身是一个管道命令,主要是以行为单位进行处理,可以将数据行进行替换、删除、新增、选取等特定工作,下面先了解一下sed的用法
. B- ?" J9 p" v( r8 t" ?1 @# Csed命令行格式为:4 ]3 c( p# o6 {% q
         sed [-nefri] ‘command’ 输入文本        
常用选项:
" Y5 U+ D" u6 }4 M1 `  h: f; V        -n∶使用安静(silent)模式。在一般 sed 的用法中,所有来自 STDIN的资料一般都会被列出到萤幕上。但如果加上 -n 参数后,则只有经过sed 特殊处理的那一行(或者动作)才会被列出来。
) B8 D0 P* i, }, w2 K2 `        -e∶直接在指令列模式上进行 sed 的动作编辑;
) J) U2 M; z7 p' ^. @1 L9 i5 K        -f∶直接将 sed 的动作写在一个档案内, -f filename 则可以执行 filename 内的sed 动作;6 B- R. I/ N. W# |. b6 L5 J
        -r∶sed 的动作支援的是延伸型正规表示法的语法。(预设是基础正规表示法语法)
6 V) l+ v' [, x9 ?0 ~" `        -i∶直接修改读取的档案内容,而不是由萤幕输出。      
常用命令:3 L# I# ^# @& w# z5 u9 M# r: [
        a   ∶新增, a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行)~  d3 Y5 o0 T5 Z' |
        c   ∶取代, c 的后面可以接字串,这些字串可以取代 n1,n2 之间的行!( G! @4 v- X! Q. v0 X7 m
        d   ∶删除,因为是删除啊,所以 d 后面通常不接任何咚咚;
5 S6 D) ]- F- c( u         i   ∶插入, i 的后面可以接字串,而这些字串会在新的一行出现(目前的上一行);: }  t9 m# O( L; Y3 [8 {
         p  ∶列印,亦即将某个选择的资料印出。通常 p 会与参数 sed -n 一起运作~
/ }$ w) L) N9 t1 N+ D1 g         s  ∶取代,可以直接进行取代的工作哩!通常这个 s 的动作可以搭配正规表示法!例如 1,20s/old/new/g 就是啦!
举例:(假设我们有一文件名为ab)& S, Z; V9 o* A  y+ N' N  n
     删除某行
0 W" G) n% k8 x     [root@localhost ruby] # sed '1d' ab              #删除第一行 " L/ r* n2 v+ g4 z
     [root@localhost ruby] # sed '$d' ab              #删除最后一行* L8 v- w. Q" |6 N! d$ J; S/ X6 ^
     [root@localhost ruby] # sed '1,2d' ab           #删除第一行到第二行
$ n* }5 ?% r0 f+ m     [root@localhost ruby] # sed '2,$d' ab           #删除第二行到最后一行
  显示某行6 @1 H4 [) D! X+ Y8 M
.    [root@localhost ruby] # sed -n '1p' ab           #显示第一行
! S/ P" x& `6 n. U     [root@localhost ruby] # sed -n '$p' ab           #显示最后一行7 l3 s! a. S) l
     [root@localhost ruby] # sed -n '1,2p' ab        #显示第一行到第二行
) \& b4 p+ P# p; P- b- }' N( i     [root@localhost ruby] # sed -n '2,$p' ab        #显示第二行到最后一行
  使用模式进行查询
0 z1 i* {/ W; q% G( I     [root@localhost ruby] # sed -n '/ruby/p' ab    #查询包括关键字ruby所在所有行
* g* a) j) R9 w) H3 K7 P     [root@localhost ruby] # sed -n '/\$/p' ab        #查询包括关键字$所在所有行,使用反斜线\屏蔽特殊含义
  增加一行或多行字符串9 F& g' h7 F$ q. D2 m: n  T
     [root@localhost ruby]# cat ab
. f+ c6 z( ?3 I( w6 {8 `+ y5 B& j4 N     Hello!
. E* z$ P0 ^8 G0 P8 Q     ruby is me,welcome to my blog.) z* T5 y3 j9 I
     end
- w0 D4 u: i) P* V) m1 T; A: a6 j     [root@localhost ruby] # sed '1a drink tea' ab  #第一行后增加字符串"drink tea"
& u! K: K- C8 S- m7 c/ `- Y' ]     Hello!1 U; w5 l! _( p
     drink tea
1 _9 c# f' w7 c+ t     ruby is me,welcome to my blog.
6 D$ b+ |1 v: f1 Y; `4 u% @# q     end6 Q: h& C# I4 L/ T' K4 G8 t; Q. U4 w$ Z
     [root@localhost ruby] # sed '1,3a drink tea' ab #第一行到第三行后增加字符串"drink tea"4 k3 z$ n0 k) s" b8 u
     Hello!. s( U; E( l# e; K  k5 Q2 T( E& w
     drink tea
7 G) o$ ]* x: X) G     ruby is me,welcome to my blog.  y: l1 s/ z! @/ f
     drink tea
2 b8 R1 a4 u1 |     end
/ H2 u6 E. u0 t+ C5 _' F     drink tea
  C* }1 m+ L9 x6 B' m9 G# ]     [root@localhost ruby] # sed '1a drink tea\nor coffee' ab   #第一行后增加多行,使用换行符\n
& F" T0 C9 ]) L# ~+ O1 E! G     Hello!
0 j4 m/ W; S0 J" y- M     drink tea
1 {0 L8 J' Z2 a     or coffee
2 w  G5 S. S, n1 E     ruby is me,welcome to my blog.
+ f# L* l! w7 C8 f6 A% P  T. t     end
  代替一行或多行
- r6 f  G& R  x* Q     [root@localhost ruby] # sed '1c Hi' ab                #第一行代替为Hi9 r! c1 c; z1 k. R! v
     Hi* M. ~: N8 {+ ^2 c& y- C
     ruby is me,welcome to my blog.# I/ L$ f* M( V3 G; ?/ Y; C
     end. F7 h7 u9 w4 x  N" h$ X# k- `- V& B
     [root@localhost ruby] # sed '1,2c Hi' ab             #第一行到第二行代替为Hi
& S" ^& _* E3 q# x( s' \     Hi
9 [! f& a) \8 s. B- Z. |     end
  替换一行中的某部分
$ U0 }% S6 h9 g, N( H  x  格式:sed 's/要替换的字符串/新的字符串/g'   (要替换的字符串可以用正则表达式)! F) `# l  \. @7 `  H6 \
     [root@localhost ruby] # sed -n '/ruby/p' ab | sed 's/ruby/bird/g'    #替换ruby为bird
% n, j8 \' p- D/ D   [root@localhost ruby] # sed -n '/ruby/p' ab | sed 's/ruby//g'        #删除ruby
     插入
* U' B9 j# b0 v2 N6 U+ a     [root@localhost ruby] # sed -i '$a bye' ab         #在文件ab中最后一行直接输入"bye"
& L# `" E6 C. f  V$ P  ^     [root@localhost ruby]# cat ab! w6 n! C! E, b2 c
     Hello!
! _: _7 U$ `' D! k) S/ h8 S     ruby is me,welcome to my blog.+ ~- ]: ~& U& g/ Y6 d
     end
, o3 b1 m0 E8 @  r9 r     bye
     删除匹配行
      sed -i '/匹配字符串/d'  filename  (注:若匹配字符串是变量,则需要“”,而不是‘’。记得好像是)
      替换匹配行中的某个字符串
      sed -i '/匹配字符串/s/替换源字符串/替换目标字符串/g' filename
! t, m% Q2 {* t, l3 q0 Q* p

. l7 O  F0 v8 X9 c3 Q& Y' R& @) r( [3 W; x, f
( ?9 M6 z4 c) @4 ?' d4 Q

3 ^) G+ \* Q! r) |5 D# Q2 I
发表于 2017-3-25 10:09 | 显示全部楼层
sed+awk只是听说过是神器,一直没机会学习,跟着楼主学起来。谢谢楼主~~~
回复

使用道具 举报

 楼主| 发表于 2017-3-25 10:14 | 显示全部楼层
zhixiaoyuhong 发表于 2017-3-25 10:094 W$ m# ^  R; u# n5 c# w
sed+awk只是听说过是神器,一直没机会学习,跟着楼主学起来。谢谢楼主~~~
9 q1 T% Y0 a3 ^6 |( \& j9 i
客气了,大家一起来学
回复

使用道具 举报

 楼主| 发表于 2017-4-13 11:51 | 显示全部楼层
linux sed命令详解
( Y% `: O; N: `( T" @简介* o# ], r" E" P$ R% O
sed 是一种在线编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有 改变,除非你使用重定向存储输出。Sed主要用来自动编辑一个或多个文件;简化对文件的反复操作;编写转换程序等。; L8 A, e# H: Z* F7 ^( V
- Y" x' m7 F: z; D, p! J
( p3 C$ n9 P7 A: a/ N1 U

, o7 _8 d/ p& u# r+ X9 k3 M  nsed使用参数9 W4 M6 j$ s' i, }4 F7 l
复制代码3 ~, n# o# b9 {9 M
[root@www ~]# sed [-nefr] [动作]
( A0 U3 P  U  V" n0 v7 @& ]选项与参数:
3 X; q% O  i! ~; W5 x-n :使用安静(silent)模式。在一般 sed 的用法中,所有来自 STDIN 的数据一般都会被列出到终端上。但如果加上 -n 参数后,则只有经过sed 特殊处理的那一行(或者动作)才会被列出来。
7 I9 |4 V9 w1 U8 P8 P* _$ N-e :直接在命令列模式上进行 sed 的动作编辑;
, v' _: d* ?& f-f :直接将 sed 的动作写在一个文件内, -f filename 则可以运行 filename 内的 sed 动作;' U3 Z6 q/ p5 I9 z
-r :sed 的动作支持的是延伸型正规表示法的语法。(默认是基础正规表示法语法)
" V* o5 m+ u! w: |) v! u# t-i :直接修改读取的文件内容,而不是输出到终端。
* r/ L7 f9 I3 l: \
: W1 j; Z  {0 j: F- S动作说明: [n1[,n2]]function
' E2 K/ A( H' r( s4 Q0 w1 ]n1, n2 :不见得会存在,一般代表『选择进行动作的行数』,举例来说,如果我的动作是需要在 10 到 20 行之间进行的,则『 10,20[动作行为] 』+ \7 O  H/ x) u' e; j" g- ?
, m6 f* v$ q% K9 t/ C) G
function:$ K' I( R, H$ b  G
a :新增, a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行)~4 f: d# A/ l: J( w. \
c :取代, c 的后面可以接字串,这些字串可以取代 n1,n2 之间的行!
) w$ Q; d- l4 ~  [+ I- G0 G, Kd :删除,因为是删除啊,所以 d 后面通常不接任何咚咚;/ o% D0 A! Q& @, {
i :插入, i 的后面可以接字串,而这些字串会在新的一行出现(目前的上一行);
) x2 g. h2 h1 e% K) v6 i0 vp :列印,亦即将某个选择的数据印出。通常 p 会与参数 sed -n 一起运行~3 ~  R/ ^( M$ m' K! b1 z
s :取代,可以直接进行取代的工作哩!通常这个 s 的动作可以搭配正规表示法!例如 1,20s/old/new/g 就是啦!) E3 D$ ^4 `! m$ o6 A; l9 l
复制代码) z7 {" J% i) Q1 I) C3 Z9 u* z+ k

: R7 N: w6 k; k2 i) ^# R5 f& A$ }6 y* I! p$ o
以行为单位的新增/删除
% o+ ~$ C5 M3 ?# H2 p% e, d% k% \! t; k) I, I- o
将 /etc/passwd 的内容列出并且列印行号,同时,请将第 2~5 行删除!
7 H; [/ \$ [& l, o
: e. j, w2 J2 U4 e2 a8 j[root@www ~]# nl /etc/passwd | sed '2,5d') f: [3 s  v: d7 Z6 |* A& `" U! {
1 root:x:0:0:root:/root:/bin/bash* A! S. d8 f* G% m7 {
6 sync:x:5:0:sync:/sbin:/bin/sync
( @7 k4 S& E6 h; s0 u$ z7 shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown1 L: h8 [4 Q, e
.....(后面省略).....
5 n+ B0 {+ v+ ?6 r; c2 |2 ]! z
5 I. I! ?9 V6 nsed 的动作为 '2,5d' ,那个 d 就是删除!因为 2-5 行给他删除了,所以显示的数据就没有 2-5 行罗~ 另外,注意一下,原本应该是要下达 sed -e 才对,没有 -e 也行啦!同时也要注意的是, sed 后面接的动作,请务必以 '' 两个单引号括住喔!
- O+ s2 {4 j4 {+ t1 h1 {2 E5 m1 V, [& V9 t0 d" f
只要删除第 2 行$ A1 c1 y8 C! V# a5 ~7 L! ]3 K2 N" z* |, A
5 e: ~7 J5 j6 ^
nl /etc/passwd | sed '2d' ) P3 ^6 h5 ~" s7 V5 s+ o

/ q- g1 X! l7 C3 m; S2 s2 ^$ ?  A( u' Q; A2 e
要删除第 3 到最后一行$ i5 |7 c2 t- f6 Z7 m( ~) d
3 x* z* c" r  y
nl /etc/passwd | sed '3,$d'
8 o7 \: ~/ g' L+ s& W  f
5 \5 ]+ r3 _2 u; o. s2 P  w) q5 Z: B% h* ?% B' e
在第二行后(亦即是加在第三行)加上『drink tea?』字样!
& o- z  I: G6 k  W% f! H1 ^
, S& J0 w1 v* d% N5 }[root@www ~]# nl /etc/passwd | sed '2a drink tea', G* I5 f$ b- U" z$ [0 l  G
1 root:x:0:0:root:/root:/bin/bash* G/ Q6 Q% z& S% m) L# m3 c2 \
2 bin:x:1:1:bin:/bin:/sbin/nologin- R  i( P: l+ I
drink tea
; @% e2 w/ S" T& n3 daemon:x:2:2:daemon:/sbin:/sbin/nologin/ w, Q1 ^) V  e2 X& D) j. r
.....(后面省略).....6 K3 q7 D3 ?. Y/ U+ c# K0 F$ \! v

1 K$ x: p/ ?, f0 X) t, i8 @8 j
% v$ r" `9 u( L6 r/ r8 m; T6 W那如果是要在第二行前
- p4 i+ l4 R! r/ G) P
: [6 G& [. o& g3 b3 ? nl /etc/passwd | sed '2i drink tea' : f3 _: E6 {( i$ X( M

9 `" k3 p* ~( i$ N) b; A( ?0 o) ?9 M9 D
如果是要增加两行以上,在第二行后面加入两行字,例如『Drink tea or .....』与『drink beer?』( G/ Q& }; b2 K) a7 P

3 X) T! Q% D* D0 h  o% ^复制代码
% Z3 t/ i+ a0 t$ q4 O& x' x. @[root@www ~]# nl /etc/passwd | sed '2a Drink tea or ......\- K/ [  s6 O  _. L: h1 Y1 T9 t* G
> drink beer ?'4 m" |( c, @* Y  |
1 root:x:0:0:root:/root:/bin/bash
2 {9 ?2 m$ k( y2 bin:x:1:1:bin:/bin:/sbin/nologin" }" I8 a* j! ]4 ]8 c: y7 K) k. T
Drink tea or ......6 s/ q% I# f7 V! F3 s3 W
drink beer ?. L( |  S8 E4 \3 a$ c0 q9 J
3 daemon:x:2:2:daemon:/sbin:/sbin/nologin1 J0 h, {6 @4 y
.....(后面省略).....
0 A; h, o1 G7 p% j复制代码+ `5 b4 S$ F3 s$ a. W  i6 v
每一行之间都必须要以反斜杠『 \ 』来进行新行的添加喔!所以,上面的例子中,我们可以发现在第一行的最后面就有 \ 存在。7 E8 _" I# v! U
! T4 j8 V( f7 D3 e# j! d

, i& }/ \( @: [2 W' d" k以行为单位的替换与显示
) M( d$ r/ y% L+ ]: I8 i& Y5 e- j. u2 S0 o- J
将第2-5行的内容取代成为『No 2-5 number』呢?) U' {1 ]6 A# i7 S2 ~: f$ a+ y, f! ?
& ?# x% f' O( q) X( X
[root@www ~]# nl /etc/passwd | sed '2,5c No 2-5 number'6 _4 m" j' \4 u& m
1 root:x:0:0:root:/root:/bin/bash
% W# f2 n7 n6 jNo 2-5 number
) k" Q# A) P5 D- D3 a2 B( t' n6 sync:x:5:0:sync:/sbin:/bin/sync
, U) N, D# b' l( d$ a$ Y.....(后面省略).....
% }* D2 m+ y8 v% P4 f' j6 U' l, G. p6 b; Q+ |
透过这个方法我们就能够将数据整行取代了!  h6 L, [2 h9 e! W% c0 d, P* p7 }/ Z: E

: ^+ w' U/ t1 z5 ]
* S( d& w4 q6 J3 k/ _& D7 q7 G8 c3 j8 k$ x; s) g) z
仅列出 /etc/passwd 文件内的第 5-7 行9 o( Y+ E0 W. {, S. \

' Z7 e+ k) s* y, h, y5 o# I[root@www ~]# nl /etc/passwd | sed -n '5,7p'! I7 |! w: L3 Y% s. l$ U- w' e/ o
5 lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin' R. f6 U) F! H- `% J. L
6 sync:x:5:0:sync:/sbin:/bin/sync9 O: g0 v( ?, X# {
7 shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
) E1 o1 _1 K9 k2 o+ r( K- X# L可以透过这个 sed 的以行为单位的显示功能, 就能够将某一个文件内的某些行号选择出来显示。' w0 i6 i5 Y1 G, J+ ~9 M: B

! Z; u/ G/ c! p7 `  P9 [. |
' ]4 v. B5 v% j% C数据的搜寻并显示8 \4 @  S$ D) Z) |  u' O
搜索 /etc/passwd有root关键字的行
  b3 t) h- s5 I) K7 [  E3 B  Y+ b& u! n+ }" G
复制代码, c4 o7 B: c7 y, d; g7 I1 o9 @4 a
nl /etc/passwd | sed '/root/p'
' L: h* y5 c8 B; `1  root:x:0:0:root:/root:/bin/bash
, s7 j3 Z: m- N7 }: P! U1  root:x:0:0:root:/root:/bin/bash
8 c/ }3 q! z  m, Y9 _2  daemon:x:1:1:daemon:/usr/sbin:/bin/sh  R0 o) }$ I0 ^7 d. }
3  bin:x:2:2:bin:/bin:/bin/sh
6 A3 ?! y8 v6 E: L! m3 a' [# p5 |4  sys:x:3:3:sys:/dev:/bin/sh, c+ x) A5 W9 `/ b
5  sync:x:4:65534:sync:/bin:/bin/sync6 G8 @. \# y( g2 \9 K( f2 s1 M3 |
....下面忽略 & |% |1 k% F2 G# T5 b& ~. o0 i5 [4 b
复制代码. o+ H: i+ o% Z; ^( a! f6 K
如果root找到,除了输出所有行,还会输出匹配行。
! J, b2 C  f0 C% ^3 ?5 Z3 z% ]1 S# `8 x1 X" R/ m4 c& p

  c/ ]( G% E& r2 _8 l. O8 F0 }& f& M
使用-n的时候将只打印包含模板的行。
+ u' L9 p) K; d2 c: S$ O1 E
" I0 \9 j5 E: J6 wnl /etc/passwd | sed -n '/root/p'
) k5 W( ^* r8 l3 ]" j, z8 s1  root:x:0:0:root:/root:/bin/bash
9 V( _; Q! A. \% I
3 G5 n' ?* j9 z; ~0 H0 f  q; f" C& |! i$ s
数据的搜寻并删除) M( L6 H- L; L
删除/etc/passwd所有包含root的行,其他行输出
! f0 W; v2 h. T4 ^; K4 k2 ~7 Z7 t1 s& W# e  n+ M* f+ w( j
nl /etc/passwd | sed  '/root/d'
3 B% `9 G% |. a; m+ o2  daemon:x:1:1:daemon:/usr/sbin:/bin/sh7 U+ O/ b& K  |- R1 `# g9 _# o9 X! i
3  bin:x:2:2:bin:/bin:/bin/sh! c- t+ a+ R$ A: |' n2 Q
....下面忽略- U8 n* U  j# f5 [4 f# T% U8 i
#第一行的匹配root已经删除了
! t. V' y5 b5 n! I9 D; M
; `! n8 P# p* `5 A
8 j7 ?8 U% w# n$ T/ w: l
+ r, W& V% B% F  ]8 Q! e& l+ Z# q% O
, f; q3 {- n8 X
- M) U" C7 M/ H) @
数据的搜寻并执行命令; }  F8 C) V" c/ _7 ^; x' `
找到匹配模式eastern的行后,
$ \+ I+ T& V. L: O! g5 U
% ?& E$ r7 L+ t9 T  Z9 n搜索/etc/passwd,找到root对应的行,执行后面花括号中的一组命令,每个命令之间用分号分隔,这里把bash替换为blueshell,再输出这行:- B  B1 O' N! ?/ X, M) A9 r
9 B2 g/ h$ \, X) J
nl /etc/passwd | sed -n '/root/{s/bash/blueshell/;p}'& _( \1 b* O8 p5 i1 `
1  root:x:0:0:root:/root:/bin/blueshell
) g! g# a! Z$ I' a如果只替换/etc/passwd的第一个bash关键字为blueshell,就退出
# k( D9 P* s7 [7 K9 t3 Y8 Z  A+ ^! d. T( U3 x
nl /etc/passwd | sed -n '/bash/{s/bash/blueshell/;p;q}'    $ C8 @, {9 p6 `, y+ [# ~7 z6 l
1  root:x:0:0:root:/root:/bin/blueshell5 R; W2 K- F& p' U
最后的q是退出。8 ^& e- L3 v) e# C

  L) J8 u7 ?1 p0 {1 Q# p; Q
6 ~  B* B5 X" l0 _- ^) I* b6 o) k4 i% ~
数据的搜寻并替换/ C7 ~8 l/ y) P5 z# M$ ^! W, K( _
除了整行的处理模式之外, sed 还可以用行为单位进行部分数据的搜寻并取代。基本上 sed 的搜寻与替代的与 vi 相当的类似!他有点像这样:1 V) x1 ~6 T: {3 K/ U* Q* R
* l; B/ r) c, X2 H8 }
sed 's/要被取代的字串/新的字串/g'
0 T3 P1 M; f+ J9 W
+ ~. V( L( Z; A$ c/ p0 T4 }9 B
* q5 c4 H. d) u' @6 b% s先观察原始信息,利用 /sbin/ifconfig 查询 IP" x& N/ z9 l" X
: c6 B( A9 r: j$ C, ^  ]
[root@www ~]# /sbin/ifconfig eth0
( D9 k4 u0 ^) l. g8 ~' e; ]eth0 Link encap:Ethernet HWaddr 00:90:CC:A6:34:84
3 f  b, w7 w. _6 Hinet addr:192.168.1.100 Bcast:192.168.1.255 Mask:255.255.255.0% q2 X' A$ E$ O% m
inet6 addr: fe80::290:ccff:fea6:3484/64 Scope:Link. T. G) w  e2 g( k6 K
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1. c+ d1 m" O, K0 Q
.....(以下省略).....
+ H" G$ ?; N" n) m0 z9 O
& I: m$ \7 B# }4 ?4 m. h本机的ip是192.168.1.100。
6 Y. C  p$ G5 i. D3 x& Q
( Y, S0 l; V0 ~1 k! {" k2 @
$ [) U+ M1 w. k2 o' c, `9 I" `& G/ ~+ u" u6 x* H/ }
将 IP 前面的部分予以删除
  J3 G8 x1 x( H$ j# E. e/ i5 e, f/ F9 g7 _! S& ]
[root@www ~]# /sbin/ifconfig eth0 | grep 'inet addr' | sed 's/^.*addr://g'- w' d  G2 W7 m' A6 [
192.168.1.100 Bcast:192.168.1.255 Mask:255.255.255.01 j+ d6 X" j. f* s- f
接下来则是删除后续的部分,亦即: 192.168.1.100 Bcast:192.168.1.255 Mask:255.255.255.0" R# m& n$ y( Y, Z/ E

& L" m; i# e2 X* k' x3 P. M1 n9 i/ A
将 IP 后面的部分予以删除; H0 f5 ?2 d6 Q* I+ I* \3 U! ~

0 P& {, t  y; R* B6 Y; f% }+ E6 q[root@www ~]# /sbin/ifconfig eth0 | grep 'inet addr' | sed 's/^.*addr://g' | sed 's/Bcast.*$//g'
/ R0 n2 v' {* M0 p; K* G3 s  b192.168.1.100+ E5 d* p" C3 U3 S0 L2 G
5 @2 T  _2 r8 w! m# c# W8 V# Y, U

( D/ `' v8 n: N多点编辑
" p! d7 z  Z1 H( Y, ^; t一条sed命令,删除/etc/passwd第三行到末尾的数据,并把bash替换为blueshell9 m* Q: R2 f) I: @

5 e- G; R, {" R1 j. Dnl /etc/passwd | sed -e '3,$d' -e 's/bash/blueshell/'& o1 B+ P5 J8 m& R0 Y- M7 o5 a
1  root:x:0:0:root:/root:/bin/blueshell+ k, F4 y2 }' @8 b
2  daemon:x:1:1:daemon:/usr/sbin:/bin/sh& Z" V6 C( V9 }  [  A+ [: p9 r* y
-e表示多点编辑,第一个编辑命令删除/etc/passwd第三行到末尾的数据,第二条命令搜索bash替换为blueshell。
$ r* d; O. n5 d; B* w4 y$ c1 ?) s

5 a- Q5 `& \5 x: f, ]
8 V  h( n3 k" ?8 @7 u: V, I 5 B5 d- y3 q7 b9 s
, `% p2 k. f! m
直接修改文件内容(危险动作)
( F. q  v  }( U, a' P, |. g5 C& u" E3 t4 g) \( F/ z
sed 可以直接修改文件的内容,不必使用管道命令或数据流重导向! 不过,由於这个动作会直接修改到原始的文件,所以请你千万不要随便拿系统配置来测试! 我们还是使用下载的 regular_express.txt 文件来测试看看吧!
8 Q; g4 V3 P1 j6 H
  K: Z. |, Q, F( Y# @7 \% q利用 sed 将 regular_express.txt 内每一行结尾若为 . 则换成 !; d5 X( P: X1 y# Q% X7 s/ o, R( P5 W  C

: J, |0 g4 \4 i[root@www ~]# sed -i 's/\.$/\!/g' regular_express.txt
5 `  w6 ~) p! K% S 3 Y( T9 z$ U) S  @5 M
$ V8 _# ^/ U  M" D
利用 sed 直接在 regular_express.txt 最后一行加入『# This is a test』  r3 @5 Q$ u5 N# W* X0 Y/ X8 r; M! F
. V9 ?2 p* j. U& r8 G. e/ N1 O
[root@www ~]# sed -i '$a # This is a test' regular_express.txt; D% _- l  f# f: ^. ?, n
由於 $ 代表的是最后一行,而 a 的动作是新增,因此该文件最后新增『# This is a test』!
1 l  T4 R* s. @) [. J& \5 u! u  @1 o& i, \. f
sed 的『 -i 』选项可以直接修改文件内容,这功能非常有帮助!举例来说,如果你有一个 100 万行的文件,你要在第 100 行加某些文字,此时使用 vim 可能会疯掉!因为文件太大了!那怎办?就利用 sed 啊!透过 sed 直接修改/取代的功能,你甚至不需要使用 vim 去修订!
8 n) K1 w1 r. b5 }+ _- Z* g3 U
/ H+ C* b7 d3 a. B" }
copycode.gif
回复

使用道具 举报

 楼主| 发表于 2017-4-13 11:57 | 显示全部楼层
" z# o  f6 R1 q' k5 z( [, Y! }* Y
1. Sed简介
- t/ }7 ^# x3 D' \  b$ E
4 S2 M& k# A6 N3 ased是一种在线编辑器,,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有 改变,除非你使用重定向存储输出。Sed主要用来自动编辑一个或多个文件;简化对文件的反复操作;编写转换程序等。以下介绍的是Gnu版本的Sed 3.02。
# f5 V$ p  b) o 0 p3 C1 y5 o! \6 o4 m# b$ i# Z. Q
方法1:
$ N# U$ o# S; K; i8 j2 | sed -i 's/被替换的内容/要替换成的内容/' file& a- g. X9 Z. B& J0 D$ ~" o
& r% O* h" k) w# |; ]5 c  x/ {
方法2:
" ?& w5 N. |- `5 a6 F1 `) Q" T sed 's/被替换的内容/要替换成的内容/g' file > file.out
9 D6 S% X0 A% H+ {- n/ ^ mv file.out file; Z% ^4 Y8 s/ N2 o6 G0 M* k* k1 o
: o$ k) C# M! p$ G% |! k" h
这里注意:
3 U( @9 }1 m: [6 n 不能这样做:) F( G& f) m) r+ U& F
sed 's/被替换的内容/要替换成的内容/g' file > file
& N. e- D  f9 Y5 r 这样只会清空源文件。* a4 T/ z+ F) I- d' D  v: w
' q4 a' M- d- d0 j; z9 P* R! `

3 r  w+ _8 a, \' p$ S+ }! _: ?2. 定址
( g6 e! x: C& |$ z
3 v6 W( m5 D. G) j8 G可以通过定址来定位你所希望编辑的行,该地址用数字构成,用逗号分隔的两个行数表示以这两行为起止的行的范围(包括行数表示的那两行)。如1,3表示1,2,3行,美元符号($)表示最后一行。范围可以通过数据,正则表达式或者二者结合的方式确定 。
0 c* E* f7 J; C# K( _   v# Z! t" |4 t7 v
0 ^2 b6 R+ {& k9 X- b
3. Sed命令& p3 }# ~3 \- K3 X- s& p/ f5 F$ \
( O7 i% h6 R' d! z2 Y$ I
调用sed命令有两种形式:
1 d! H2 l: `5 _0 l & b7 F2 k9 F& r1 k! L

2 c' F  a4 X, B( D. @) Ised [options] 'command' file(s)
6 @! ?$ |  k  _8 g8 Q' I + l6 ]# {0 f% k% }/ v( G
sed [options] -f scriptfile file(s)
- E4 i) q6 j) Q! A/ x
( \0 G4 q. f9 z* z
  y  e6 I* q$ |< * M- j2 |! S% x$ o* z& r; \
a\
& G0 d1 `" [  b+ M3 y# l8 v 在当前行后面加入一行文本。
3 N4 k1 h$ J" D8 R
4 f7 b; M0 R' kb lable
, p. M4 K6 V8 ]! u+ S+ g& f% f 分支到脚本中带有标记的地方,如果分支不存在则分支到脚本的末尾。3 C  a1 T" Z3 B* V" X
3 ?) W. ^- m' x( {
c\
+ ^2 a/ W, \8 }$ u 用新的文本改变本行的文本。+ \* ?. m' j! O8 Q1 X' v: e

/ y1 _) ]& z, }1 Z: G: gd
6 r6 S. H* v! ^# l, `- B. x' t$ L 从模板块(Pattern space)位置删除行。5 H+ y: H" [" t- d& W. @

1 [6 U$ M, J' n% ]2 B, BD 5 H1 j, ], Z9 v$ o
删除模板块的第一行。
( T* b3 n: t; G" ^0 J ( \: j9 r4 F! z1 l+ |- v
i\
  H7 S& e: f7 `0 A# P 在当前行上面插入文本。
$ `: Y9 Q2 }: M7 h
% F" _  e$ x) _% q3 m# P4 i0 ih
( a! o# d, |$ V3 h. |# x. F 拷贝模板块的内容到内存中的缓冲区。
4 X+ s- X% g% m* U0 {
! D% h: ^" `& G: f$ H1 O. z# rH   h0 m7 I9 _" Z7 y  ]& R
追加模板块的内容到内存中的缓冲区7 b8 ?/ v1 j- n( w/ R

2 ~% n" k4 c2 ^% h, a; l7 R, Q8 vg 0 l3 I+ U8 d8 m
获得内存缓冲区的内容,并替代当前模板块中的文本。
5 x) [: `3 `8 ^' k# K! j + S1 V  J. k4 m3 \. s( `' N
G
0 v0 K- r( A0 h; {/ I9 g 获得内存缓冲区的内容,并追加到当前模板块文本的后面。+ V8 T. z/ ~: B) O/ ^

, e2 X& o( r6 L( j# a9 `# sl % G3 T# n- p9 {4 {9 H" `
列表不能打印字符的清单。& ~2 V& b+ d; w' F' b+ B

9 q8 e/ @( e  b/ S) ^, Hn : `6 H- e! L, d( A. D& l) l
读取下一个输入行,用下一个命令处理新的行而不是用第一个命令。( o' P# L2 m2 i6 d1 _% ]' T4 g

" f; o/ c. y  \1 FN # l1 ^6 t9 M3 V- @4 O; i2 c
追加下一个输入行到模板块后面并在二者间嵌入一个新行,改变当前行号码。3 K/ C; Q. l* X0 l9 C" s0 x

2 F: Q2 x( }6 k4 y3 y3 gp 0 h$ B0 \- C; u' i6 }! G
打印模板块的行。) d1 d& S$ v" G9 b% c" E9 C: F9 I# T
2 j8 j  i# _) f( s
P(大写)
; b) v: b. t1 \. [ 打印模板块的第一行。+ ^1 T& b% b+ r. l* ]1 T

. D  K% C* X7 v' m' h3 }q
/ u. m* M0 Q9 p4 h/ I 退出Sed。7 e  w* W( o* `' y( Q) E
( G7 K. e5 B6 n6 U
r file 8 y# h- Z# f' h8 y; w" Z
从file中读行。
& _  m7 t2 _- H! F
9 L* ~% {% b7 o( }& l/ ?t label
- O. j* C6 |% W: g* W' Q if分支,从最后一行开始,条件一旦满足或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾。9 O6 T6 B+ M3 u$ Q; ?

( O7 K8 G2 Y3 p2 c& f0 eT label
& x( q( K' X  m9 A6 i+ R; w 错误分支,从最后一行开始,一旦发生错误或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾。
& z, F; b, S, H( Z$ K3 U' U- j4 u
; l& v9 e% z, Q; ?" M  Uw file
. ~$ i# G; A3 K  x4 a$ \  b5 | 写并追加模板块到file末尾。
2 |. s7 I5 Q( ?9 a: d2 Q# W + N6 W% W# Z: n2 ?2 G& I
W file
4 y- ^' U: [! V$ u( ?5 H 写并追加模板块的第一行到file末尾。7 Z% d6 o! t4 C0 k
1 J. L4 ?8 k2 v" |9 O- x
!
$ J$ ^& F- K* Z4 Z 表示后面的命令对所有没有被选定的行发生作用。
9 ?2 Z; u5 |; m7 L, A7 A
- k( f1 t2 c1 U1 o' b: Cs/re/string % I! [1 r0 L5 g) a' t9 ^% @# c
用string替换正则表达式re。
7 L% M0 G3 t/ G( s% }% M
' A# n) w( s) f$ f6 e=
; t- O1 D  n: Y( M- { 打印当前行号码。
/ B, a) N0 S! |
' {4 D! Y$ y2 f3 ^' D# " F: v2 F& ~. l1 Q
把注释扩展到下一个换行符以前。2 |8 ]8 ?, @4 k
+ d4 _; G$ Y! Y' j; G' U% Q  H
以下的是替换标记
* l4 U3 F: x) r9 c1 I
. b/ Q2 i. R* X: m4 }5 }g表示行内全面替换。
% j' [; |1 c4 m) _+ B 4 t, c; n3 m( G- Q6 U5 z
p表示打印行。
9 q# L: d5 H: B+ ]5 g& r: f $ p" `$ B  P0 w' e. Z
w表示把行写入一个文件。
9 C. r& {1 K  L/ A7 ] + _; U# P8 p, l1 L8 c
x表示互换模板块中的文本和缓冲区中的文本。
2 b) g$ A/ i. [9 a + U4 |6 F) d' K) [# d
y表示把一个字符翻译为另外的字符(但是不用于正则表达式)
( K  _# G* l/ C# Q2 O. f# Q
- P9 `, u1 H/ O2 f. elinux
回复

使用道具 举报

本版积分规则

QQ|一淘宝店|手机版|商店|一乐电子 ( 粤ICP备09076165号 ) 公安备案粤公网安备 44522102000183号

GMT+8, 2025-8-20 09:21 , Processed in 0.037307 second(s), 29 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表