sed文本处理工具

Sed是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有改变,除非你使用重定向存储输出。Sed主要用来自动编辑一个或多个文件,简化对文件的反复操作,编写转换程序等。
下面来说说它的用法:
sed [option]… ‘script’ inputfile
sed:
-n:取消自动打印,输出到屏幕。
-e: 多点编辑,对每行处理时,可以有多个Script 即可以跟多个命令。
-f: 把Script写到文件当中,在执行sed时-f 指定文件路径,如果是多个Script,换行写
-r: 支持扩展的正则表达式
-i: 直接将处理的结果写入文件
-i.bak  在将处理的结果写入文件之前先备份
script
地址定界:
(1) 不给地址:对全文进行处理
如:sed -n ‘p’ 文件
(2) 单地址:
#: 指定的行
如:sed -n ‘2p’ 文件
/pattern/:被此处模式所能够匹配到的每一行
如:sed -n ‘/linux/p’文件
(3) 地址范围:
#,#
如:sed -n ‘2,3p’
#,+#
如: sed -n ‘2,+1p’
/pat1/,/pat2/
如: sed -n ‘/redhat/,/linux/p’
#,/pat1/
如:sed -n ‘2,/linux/p’
(4) ~:步进
1~2 奇数行
2~2 偶数行
如:sed -n ‘1~2p’  只打印奇数行
sed -n ‘2~2p’  只打印偶数行

编辑命令:
d: 删除模式空间匹配的行,并立即启用下一轮循环
如:sed ‘2d’ /etc/passwd (删除/etc/passwd文件中的第二行)
p:打印当前模式空间内容,追加到默认输出之后
如:sed ‘2p’ /etc/passwd
a [\]text:在指定行后面追加文本,支持使用\n实现多行追加
如:sed ‘2a\123\n456\n789‘ /etc/passwd
i [\]text:在行前面插入文本
如:sed ‘2i\123\n456\n789’ /etc/passwd
c [\]text:替换行为单行或多行文本
如:sed ‘2c\123\n456\n789’ /etc/passwd
w /path/somefile: 保存模式匹配的行至指定文件
如:sed -n ‘3w /root/3.file’ /root/bin
r /path/somefile:读取指定文件的文本至模式空间中匹配到的行后
如:sed ‘3r /root/mage.txt’ /etc/passwd
=: 为模式空间中的行打印行号
如:sed ‘=’ /etc/fstab
!:模式空间中匹配行取反处理
如:sed -n ‘2!p’ /etc/fstab
s///:查找替换,支持使用其它分隔符,s@@@,s###替换标记。
如:sed -n ‘s/root/rooter/g’ /etc/passwd
g: 行内全局替换
如:sed ‘s/root/rooter/g’ /etc/passwd
p: 显示替换成功的行
如:sed -n ‘s/root/rooter/gp’ /etc/passwd
w /PATH/TO/SOMEFILE:将替换成功的行保存至文件中
高级编辑命令:
h: 把模式空间中的内容覆盖至保持空间中
H:把模式空间中的内容追加至保持空间中
g: 从保持空间取出数据覆盖至模式空间
G:从保持空间取出内容追加至模式空间
x: 把模式空间中的内容与保持空间中的内容进行互换
n: 读取匹配到的行的下一行覆盖至模式空间
N:读取匹配到的行的下一行追加至模式空间
d: 删除模式空间中的行
D:删除当前模式空间开端至\n的内容(不再传至标准输出),放弃之后的命令,但是对剩余模式空间重新执行sed
示例:
sed -n ‘n;p’ FILE  显示偶数行
sed ‘1!G;h;$!d’ FILE  倒序显示
sed -n ‘1!G;h;$p’ 倒序显示
seq 7 |sed ‘n;d’ 显示奇数
sed  ‘N;D’ 显示最后一行
sed ‘$!d’  显示最后一行
sed ‘G’  每行之间加空行
sed ‘g’  把每行内容替换成空行
sed ‘/^$/d;G’  确保每一行下面都有一个空行

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/89141

(0)
凉生凉生
上一篇 2017-12-01
下一篇 2017-12-02

相关推荐

  • LVM应用

    1、创建一个2G的文件系统,块大小为2048byte,预留1%可用空间,文件系统ext4,卷标为TEST,要求此分区开机后自动挂载至/test目录,且默认有acl挂载选项 ·首先在虚拟机当中添加指定大小的硬盘,添加完成后,系统不会自动扫描添加的硬盘设备,键入命令重新扫描SCSI总线来添加设备   echo "- – -&quo…

    Linux干货 2016-08-30
  • 文本三剑客—sed 基础

    文本三剑客—sed 基础        sed编辑器被称作流编辑器(stream editor),和普通的交互式文本编辑器恰好相反。在交互式文本编辑器中(比如vim),你可以用键盘命令来交互式的插入、删除或者替换数据中的文本。流编辑器则会自爱编辑器处理数据之前基于预习提供的一组…

    Linux干货 2017-05-15
  • iptables

    iptables Firewall:防火墙 隔离工具;Packets Filter Firewall;工作于主机或网络的边缘,对经由的报文根据预先定义的规则(匹配条件)进行检测,对于能够被规则匹配到的报文实行某预定义的处理机制的一套组件; 分类: 硬件防火墙:在硬件级别实现部分功能的防火墙;另一个部分功能基于软件实现; 软件防火墙:应用软件处理逻辑运行于通用…

    Linux干货 2016-11-07
  • 第二周博客作业

    一、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示 Linux文件管理类命令有cp、mv、rm 1、cp命令:copy files and directories 使用方法: 单源复制cp [OPTION]… [-T] SOURCE DEST1)如果DEST不存在,则事先创建此文件,并复制源文件的数据流至DEST中2)如果…

    Linux干货 2016-12-13
  • 马哥教育网络班20期+第二周课程练习

    linux 中一切皆文件,我们所做的一切都是和文件打交道。   文件分为两部分:元数据和数据           元数据: 即真实数据的属性。可用 stat  命令查看       &nbs…

    Linux干货 2016-06-23
  • Linux的SOCKET编程详解

    1. 网络中进程之间如何通信 进 程通信的概念最初来源于单机系统。由于每个进程都在自己的地址范围内运行,为保证两个相互通信的进 程之间既互不干扰又协调一致工作,操作系统为进程通信提供了相应设施,如 UNIX BSD有:管道(pipe)、命名管道(named pipe)软中断信号(signal) UNIX system V有:消息(message)、共享存储区…

    Linux干货 2015-04-10