当前位置:七道奇文章资讯系统安全Linux安全
日期:2011-08-02 11:45:00  来源:本站整理

linux sed号令详解[Linux安全]

赞助商链接



  本文“linux sed号令详解[Linux安全]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
  1. Sed简介
  sed 是一种在线编辑器,它一次处理一行内容.处理时,把当前处理的行存储在暂时缓冲区中,称为"情势空间"(pattern space),接着用sed号令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕.接着处理下一行,这样不断反复,直到文件末尾.文件内容并没有 改变,除非你利用重定向存储输出.Sed主要用来自动编辑一个或多个文件;简化对文件的反复操作;编写转换程序等.以下介绍的是Gnu版本的Sed 3.02.
  2. 定址
  可以通过定址来定位你所但愿编辑的行,该地址用数字构成,用逗号脱离的两个行数表示以这两行为起止的行的范围(包含行数表示的那两行).如1,3表示1,2,3行,美圆标记($)表示最后一行.范围可以通过数据,正则表达式大概二者结合的方法肯定 .
  3. Sed号令
  调用sed号令有两种情势:
  *
  sed [options] 'command' file(s)
  *
  sed [options] -f scriptfile file(s)
  a\
  在当前行背面加入一行文本.
  b lable
  分支到脚本中带有标志的地方,假如分支不存在则分支到脚本的末尾.
  c\
  用新的文本改变本行的文本.
  d
  从模板块(Pattern space)位置删除行.
  D
  删除模板块的第一行.
  i\
  在当前行上面插入文本.
  h
  拷贝模板块的内容到内存中的缓冲区.
  H
  追加模板块的内容到内存中的缓冲区
  g
  得到内存缓冲区的内容,并替换当前模板块中的文本.
  G
  得到内存缓冲区的内容,并追加到当前模板块文本的背面.
  l
  列表不能打印字符的清单.
  n
  读取下一个输入行,用下一个号令处理新的行而不是用第一个号令.
  N
  追加下一个输入行到模板块背面并在二者间嵌入一个新行,改变当前行号码.
  p
  打印模板块的行.
  P(大写)
  打印模板块的第一行.
  q
  退出Sed.
  r file
  从file中读行.
  t label
  if分支,从最后一行开始,条件一旦满意大概T,t号令,将招致分支到带有标号的号令处,大概到脚本的末尾.
  T label
  错误分支,从最后一行开始,一旦发生错误大概T,t号令,将招致分支到带有标号的号令处,大概到脚本的末尾.
  w file
  写并追加模板块到file末尾.
  W file
  写并追加模板块的第一行到file末尾.
  !
  表示背面的号令对全部没有被选定的行发生作用.
  s/re/string
  用string替换正则表达式re.
  =
  打印当前行号码.
  #
  把注释扩大到下一个换行符从前.
  以下的是替换标志
  *
  g表示行内全面替换.
  *
  p表示打印行.
  *
  w表示把行写入一个文件.
  *
  x表示交换模板块中的文本和缓冲区中的文本.
  *
  y表示把一个字符翻译为别的的字符(但是不用于正则表达式)
  4. 选项
  -e command, --expression=command
  允很多台编辑.
  -h, --help
  打印帮忙,并显示bug列表的地址.
  -n, --quiet, --silent
  撤消默许输出.
  -f, --filer=script-file
  指导sed脚本文件名.
  -V, --version
  打印版本和版权信息.
  5. 元字符集^
  锚定行的开始 如:/^sed/匹配全部以sed开首的行.
  $
  锚定行的完毕 如:/sed$/匹配全部以sed末尾的行.
  .
  匹配一个非换行符的字符 如:/s.d/匹配s后接一个肆意字符,然后是d.
  *
  匹配零或多个字符 如:/*sed/匹配全部模板是一个或多个空格后紧跟sed的行.
  []
  匹配一个指定范围内的字符,如/[Ss]ed/匹配sed和Sed.
  [^]
  匹配一个不在指定范围内的字符,如:/[^A-RT-Z]ed/匹配不包含A-R和T-Z的一个字母开首,紧跟ed的行.
  \(\)
  保存匹配的字符,如s/\(love\)able/\1rs,loveable被替换成lovers.
  &
  保存搜索字符用来替换其他字符,如s/love/**&**/,love这成**love**.
  \<
  锚订单词的开始,如:/\<love/匹配包含以love开首的单词的行.
  \>
  锚订单词的完毕,如/love\>/匹配包含以love末尾的单词的行.
  x\{m\}
  反复字符x,m次,如:/0\{5\}/匹配包含5个o的行.
  x\{m,\}
  反复字符x,至少m次,如:/o\{5,\}/匹配至少有5个o的行.
  x\{m,n\}
  反复字符x,至少m次,不多于n次,如:/o\{5,10\}/匹配5--10个o的行.
  6. 实例
  删除:d号令
  *
  $ sed '2d' example-----删除example文件的第二行.
  *
  $ sed '2,$d' example-----删除example文件的第二行到末尾全部行.
  *
  $ sed '$d' example-----删除example文件的最后一行.
  *
  $ sed '/test/'d example-----删除example文件全部包含test的行.
  替换:s号令
  *
  $ sed 's/test/mytest/g' example-----在整行范围内把test替换为mytest.假如没有g标志,则只有每行第一个匹配的test被替换成mytest.
  *
  $ sed -n 's/^test/mytest/p' example-----(-n)选项和p标志一同利用表示只打印那些发生替换的行.也就是说,假如某一行开首的test被替换成mytest,就打印它.
  *
  $ sed 's/^192.168.0.1/&localhost/' example-----&标记表示替换换字符串中被找到的部份.全部以192.168.0.1开首的行城市被替换成它自已加localhost,变成192.168.0.1localhost.
  *
  $ sed -n 's/\(love\)able/\1rs/p' example-----love被标志为1,全部loveable会被替换成lovers,并且替换的行会被打印出来.
  *
  $ sed 's#10#100#g' example-----不管什么字符,紧随着s号令的都被认为是新的脱离符,所以,"#"在这里是脱离符,替换了默许的"/"脱离符.表示把全部10替换成100.
  选定行的范围:逗号
  *
  $ sed -n '/test/,/check/p' example-----全部在模板test和check所肯定的范围内的行都被打印.
  *
  $ sed -n '5,/^test/p' example-----打印从第五行开始到第一个包含以test开始的行之间的全部行.
  *
  $ sed '/test/,/check/s/$/sed test/' example-----关于模板test和west之间的行,每行的末尾用字符串sed test替换.
  多点编辑:e号令
  *
  $ sed -e '1,5d' -e 's/test/check/' example-----(-e)选项答应在同一行里履行多条号令.如例子所示,第一条号令删除1至5行,第二条号令用check替换test.号令的执 行次序对后果有影响.假如两个号令都是替换号令,那么第一个替换号令将影响第二个替换号令的后果.
  *
  $ sed --expression='s/test/check/' --expression='/love/d' example-----一个比-e更好的号令是--expression.它能给sed表达式赋值.
  从文件读入:r号令
  *
  $ sed '/test/r file' example-----file里的内容被读进来,显示在与test匹配的行背面,假如匹配多行,则file的内容将显示在全部匹配行的下面.
  写入文件:w号令
  *
  $ sed -n '/test/w file' example-----在example中全部包含test的行都被写入file里.
  追加号令:a号令
  *
  $ sed '/^test/a\\--->this is a example' example<-----'this is a example'被追加到以test开首的行背面,sed要求号令a背面有一个反斜杠.
  插入:i号令
  $ sed '/test/i\\
  new line
  -------------------------' example
  假如test被匹配,则把反斜杠背面的文本插入到匹配行的前面.
  下一个:n号令
  *
  $ sed '/test/{ n; s/aa/bb/; }' example-----假如test被匹配,则移动到匹配行的下一行,替换这一行的aa,变成bb,并打印该行,然后持续.
  变形:y号令
  *
  $ sed '1,10y/abcde/ABCDE/' example-----把1--10行内全部abcde改变成大写,注意,正则表达式元字符不能利用这个号令.
  退出:q号令
  *
  $ sed '10q' example-----打印完第10行后,退出sed.
  保持和获得:h号令和G号令
  *
  $ sed -e '/test/h' -e '$G example-----在sed处理文件的时刻,每一行都被保存在一个叫情势空间的暂时缓冲区中,除非行被删除大概输出被撤消,不然全部被处理的行都将 打印在屏幕上.接着情势空间被清空,并存入新的一行等候处理.在这个例子里,匹配test的行被找到后,将存入情势空间,h号令将其复制并存入一个称为保 持缓存区的特别缓冲区内.第二条语句的意思是,当到达最后一行后,G号令取出保持缓冲区的行,然后把它放回情势空间中,且追加到目前已经存在于情势空间中 的行的末尾.在这个例子中就是追加到最后一行.简单来说,任何包含test的行都被复制并追加到该文件的末尾.
  保持和交换:h号令和x号令
  *
  $ sed -e '/test/h' -e '/check/x' example -----交换情势空间和保持缓冲区的内容.也就是把包含test与check的行交换.
  7. 脚本
  Sed脚本是一个sed的号令清单,启动Sed时以-f选项指导脚本文件名.Sed关于脚本中输入的号令非常挑剔,在号令的末尾不能有任何空白或文本,假如在一行中有多个号令,要用分号脱离.以#开首的行为注释行,且不能跨行
  以上是“linux sed号令详解[Linux安全]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • windows下的近似linux下的grep号令--findstr
  • linux下mysql链接被防火墙禁止的办理办法
  • Linux下mysql新建账号及权限设置办法
  • SUSE Linux下搭建Web服务器
  • Windows/Linux MySQL忘掉密码重置密码教程
  • Linux下Apache自动监测重启脚本(智能化程度较高)
  • linux备份 linux克隆 linux clone
  • <b>为什么 Linux不需求碎片整理</b>
  • CentOS6 yum搭建Linux+Nginx+PHP+MYSQL(LNMP)
  • Linux系统有效防备ARP攻击
  • Linux下 Memcache的安装和简单管理
  • 笔记本预装linux重装成windows系统
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .