文本三剑客之sed

简要概括sed

一、流编辑器,逐行处理文本内容。处理方式由子命令指定,在内存中完成处理,默认不修改源文件。
语法格式:sed 【-选项】 ‘/过滤筛选/子命令/子命令选项’ 文本对象文件

二、sed用法:

sed[option]..   ‘script’ inpututfile….

常用选项:

-n:不输出模式空间内容到屏幕,即不自动打印
-e:多点编辑
-f: /PATH/SCRIPT_FILE:从指定文件读取编辑脚本
-r:支持使用扩展正则表达式
-i:.bak:备份文件并原处编辑

scipt:“地址命令”

三、sed工具:
地址定界:
1、不给地址:对全文进行处理
2、单地址:
#:指定的行,$:最后一行
/pattern/:被此处模式所能匹配到的每一行
3、地址范围:
#,#
#,+#
/pat1/,/pat2/
#,/pat1/
4、~:步进
1~2奇数行
2~2偶数行

四、

编辑命令:
d:删除模式空间匹配的行,并立即启用下一轮循环
p:打印当前模式空间内容,追加到默认输出之后
a[\]test:在指定行后面追加文本
支持使用\n实现多行追加
i[\]test :在行前插入文本
c[\]test: 替换行为单行或多行文本
w /path/somefile:保存模式匹配的行至指定文件
r /path/somefile:读取指定文件的文本至模式空间中 匹配到的行后
=:为模式空间中的行打印行号
!:模式空间中匹配行取反处理

s///:查找替换,支持使用其他分隔符,s@@2,s###
替换标记:
g:行内全局替换
p:显示替换成功的行
w /PATH/TO/SOMEFILE:将替换成功的行保存至文件中

sed示例:
sed ‘2p’ /etc/passwd
sed -n ‘2p’ /etc/passwd
sed-n ‘1,4p’ /etc/passwd
sed -n ‘/root/p’ /etc/passwd
sed -n ‘2,/root/p’ /etc/passwd 从2行开始
sed -n ‘/^$/=’ fle 显示空行行号
sed -n -e ‘/^$/p’ -e ‘/^$/=’ file
sed ‘root/a\superman’ /etc/passwd行后
sed ‘root/i\superman’ /etc/passwd行前
sed ‘root/c\superman’ /etc/passwd代替行

sed示例:
sed ‘/^$/d’ file
sed ‘1,10d’ file
nl /etc/passwd| sed ‘2,5d’
nl /etc/passwd| sed ‘2a tea’
sed ‘s/test/mytest/g’ example
sed -n ‘s/root/&superman/p’ /etc/passwd 单词后
sed -n ‘s/root/superman&/p’ /etc/passwd单词前
sed -e ‘s/dog/cat/’ -e ‘s/hi/lo/’ pets
sed -i.bak ‘s/dog/cat/g’ pets

五、

高级编辑命令:
p: 打印模式空间开端至\n内容,并追加到默认输出之前
h: 把模式空间中的内容覆盖至保持空间中
H:把模式空间中的内容追加至保持空间中
g: 从保持空间取出数据覆盖至模式空间
G:从保持空间取出内容追加至模式空间
x:把模式空间中的内容与保持空间中的内容进行互换
n:读取匹配到的行的下一行覆盖至模式空间
N:读取匹配到的行的下一行追加至模式空间
d:删除模式空间中的行
D:如果模式空间包含换行符,则删除知道第一个换行符的模式空间中的文本,
并不会读取新的输入行,而使用合成的模式空间重新启动循环。如果模式空间
不包含换行符,则会想发出d命令那样启动正常的新循环

sed示例:
sed-n ‘n;p’ FILE
sed ‘1!G;h;$!d FILE
sed ‘N;D ‘ FILE
sed ‘$!d’ FILE
sed ‘$!N;$!D’ FILE
sed ‘G’ FILE
sed ‘g’ FILE
sed ‘/^$/d;G’ FILE
sed ‘n;d’ FILE
sed -n ‘1!G;h;$p’ FILE

命令
用法
N
读取新的输入行,并将该行追加到模式空间现有内容之后,来创建多行模式空间。创建后的多行模式空间中,原有内容和新内容用换行符”\n”来分割。
而执行N命令之后,将会继续执行,N之后的命令,N之后命令的对象则是我们新的模式空间的内容。
注意:多行模式空间中,^匹配整个空间的开始,$匹配整个空间的结尾,
比如上面的 1\n2\n3 开头是1,结尾是3
$!N,最后一行,不执行N命令
D
删除模式空间中,从头开始到第一个嵌入的换行符为止。
它并不会导致新行的输入,而是会返回脚本的顶端,将这些指令应用于空间中剩余的内容
P
输出模式空间中,从头开始到第一个嵌入的换行符为止。
实际运用中,P经常放到N之后,P之前
n
输出当前模式空间的内容,读取下一行替换当前行,替换之后,n命令之后的命令作用到新行上
d
情况模式空间,并导致新行的读入,此时控制将忽略d之后的命令,并转移到脚本的顶端,作用在新的输入行上
p
打印整个模式空间的内容。其他的对模式空间,没啥影响了。

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

(0)
上一篇 2018-04-29 15:39
下一篇 2018-04-29 18:02

相关推荐

  • cobbler自动化安装

    实验:实现cobbler安装 1 安装包 yum install cobbler(EPEL) dhcp httpd tftp systemctl enable cobblerd dhcpd httpd tftp systemctl start cobblerd httpd tftp 2 cobbler check 3 vim /etc/cobbler/set…

    Linux笔记 2018-05-27
  • 加密和安全

    加密和安全

    2018-05-17
  • ansible实战应用之角色装nginx,httpd

    流程图如下: 上图表明: 1).tasks夹: .grupyml .useryml: 指定uid;gid,且最好uid和gid统一,这样好管理要;加入组中;一般来说建一个帐号是给特定的服务用的,一般来讲这个帐号 都是系统帐号;且它的shell类型,为了安全一般都是/sbin/nologin * 不确定uid号有没有人有的话,可以用#getent passwd…

    Linux笔记 2018-06-03
  • SAMBA服务介绍及相关实验

    Samba是在Linux和UNIX系统上实现SMB协议的一个免费软件,由服务器及客户端程序构成。SMB(Server Messages Block,信息服务块)是一种在局域网上共享文件和打印机的一种通信协议,它为局域网内的不同计算机之间提供文件及打印机等资源的共享服务。

    2018-06-29
  • 第五周

    第五周作业 简述rpm与yum命令的常见选项,并举例 Rpm: -a, –all                        查询/验证所有软件包 -f, –file                       查询/验证文件属于的软件包 -g, –group                      查询/验证组中的软…

    Linux笔记 2018-07-23
  • SSH端口转发实验

      本节索引: 一、SSH端口转发相关概念 二、实验:模拟SSH本地端口转发 三、实验:模拟SSH远程端口转发 四、实验:模拟SSH动态端口转发   一、SSH端口转发相关概念 在上一节我们知道,SSH会自动加密和解密所有SSH客户端和服务器之间的网络数据。但是,SSH还同时 提供了一个非常有用的功能,这就是端口转发。它能够将其他TCP端…

    Linux笔记 2018-05-22