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

相关推荐

  • 数组,字符串切片,高级变量

    数组 变量:存储单个元素的内存空间 数组:存储多个元素的连续的内存空间,相当于多个变量的集合 数组名和索引 索引:编号从0开始,属于数值索引 注意:索引可支持使用自定义的格式,而不仅是数值格式,即为关联索引 bash4.0版本之后开始支持 bash –version   查看bash版本 bash的数组支持稀疏格式(索引不连续) 声明数组: de…

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

    加密和安全

    2018-05-17
  • Day06笔记总结:grep与正则表达式

    Title: grep与正则表达式
    Date: 2018-04-08
    Author: Alvin

    Linux笔记 2018-04-08
  • 加密和安全

    常见的加密算法和安全协议 一、对称加密:加密和解密使用同一个密钥,依赖于算法和密钥,其安全性依赖于密钥而非算法 常见的算法:DES ​ 特性: ​ 加密、解密使用同一个密钥 ​ 将明文分隔成固定的大小块逐个进行加密 ​ 缺点: ​ 密钥过多、密钥分发 二、非对称加密:采用的是公钥加密方法,密钥是成对出现的,公钥是从私钥中提取出来的 ​ 公钥:公开给所有人;p…

    Linux笔记 2018-05-10
  • 粗谈用户和用户组相关配置文件

    创建一个用户时,用户会根据系统配置文件来创建用户。配置文件在/etc/login.defs文件里 login.defs //创建账户自动分配参数 PASS_MAX_DAYS //可以使用密码的最大天数。 PASS_MIN_DAYS //密码更改之间允许的最短天数 PASS_MIN_LEN //最小可接受的密码长度 PASS_WARN_AGE //密码过期前发…

    Linux笔记 2018-04-08
  • linux基础知识

    本博文写的是linux的基础知识,比较杂,但是都很重要。

    Linux笔记 2018-07-22