文本三剑客之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

相关推荐

  • Linux计算MD5和Sha1的命令

    Linux计算MD5和Sha1的命令

    Linux笔记 2018-06-07
  • linux 学习6

    1、简述osi七层模型和TCP/IP五层模型 1、 osi七层模型 1、应用层:OSI 参考模型中最靠近用户的一层,为计算机用户提供应用接口,也为用户直接提供各种网络服务。我们常见应用层的网络服务协议有:HTTP,HTTPS,FTP,POP3、SMTP等。 2、表示层:提供各种用于应用层数据的编码和转换功能,确保一个主机的应用层发送的数据能被另一个主机的应用…

    Linux笔记 2018-07-28
  • linux入门命令

    bc:计算器 mainframe 缓存查看:lscpu磁盘和内存性能测试命令: dd Xmanager (xshell) 安装:用户名: byg公司: microsoft注册码: 使用工具生成 命令库调用: # ldd /bin/ls系统库跟踪,调用库详细信息 # strace lslibrary 库跟踪 # ltrace ls 二进制文件查看: # hex…

    Linux笔记 2018-07-21
  • 创建配置格式文件的格式 C语言源代码安装三步骤 yum

    创建配置文件的格式: [base] name= centos cdrom mirrorlist=file:///root/baselist gpgkey=file:///mnt/cdrom/rpm-gpg-key-centos-7     [epel] name=epel baseurl=https://mirrors aliyun.co…

    Linux笔记 2018-04-22
  • Linux文件权限详解

    Linux系统中不仅是对用户与组根据UID,GID进行了管理,还对Linux系统中的文件,按照用户与组进行分类,针对不同的群体进行了权限管理,用他来确定谁能通过何种方式对文件和目录进行访问和操作。

    2018-04-04
  • 震惊!!!原来CentOS-7装起来这么容易

    震惊!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

    2018-07-22