加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Linux > 正文

Linux sed命令

发布时间:2020-12-14 02:08:39 所属栏目:Linux 来源:网络整理
导读:Linux sed命令 语法 sed [选项] [动作] [文本文件] 选项 -n 使用安静(silent)模式,仅显示sed处理过的行; -e script文件 以选项中指定的script来处理输入的文本文件;多重编辑,命令顺序会影响结果; -f script文件 以选项中指定的script文件来处理输入的文

Linux sed命令

语法
sed [选项] [动作] [文本文件]

选项
-n 使用安静(silent)模式,仅显示sed处理过的行;
-e <script文件> 以选项中指定的script来处理输入的文本文件;多重编辑,命令顺序会影响结果;
-f <script文件> 以选项中指定的script文件来处理输入的文本文件;
-i 编辑文件(注意备份)


常用动作
a 在当前行下面插入文本。
i 在当前行上面插入文本。
c 把选定的行改为新的文本。
d 删除,删除选择的行。
s 替换指定字符
p 打印模板块的行,通常与sed -n使用。
g 在行内进行全局替换


sed元字符集
^ 匹配行首,如:/^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个0的行。
x{m,} 重复字符x,至少m次,如:/0{5,}/匹配至少有5个0的行。
x{m,n} 重复字符x,至少m次,不多于n次,如:/0{5,10}/匹配5~10个0的行。


增("a","i")
在第二行下面插入“test line”
sed ‘2atest line‘ test.txt

在第二行上面插入“test line”
sed ‘2itest line‘ test.txt

在keyword开头的行下面插入“test line”
sed ‘/^keyword/atest line‘ test.txt

在keyword开头的行上面插入“test line”
sed ‘/^keyword/itest line‘ test.txt



删除第3行
sed ‘3d‘ test.txt

删除第2~5行
sed ‘2,5d‘ test.txt

删除第5行到最后一行
sed ‘5,$d‘ test.txt

删除所有包含keyword的行
sed ‘/keyword/d‘ test.txt

删除所有以keyword开头的行
sed ‘/^keyword/d‘ test.txt

删除空白行:
sed ‘/^$/d‘ test.txt

删除最后一行:
sed ‘$d‘ test.txt


改、替换
将文件中字符串keyword替换成kkkkkkk(后缀 /g 表示匹配文件中的每一行)
sed ‘s/keyword/kkkkkkk/g‘ test.txt

当需要从每一行第N处匹配开始替换时,可以使用 /Ng
sed ‘s/keyword/kkkkkkk/2g‘ test.txt

-n选项和p命令一起使用表示只打印那些发生替换的行:
sed -n ‘s/keyword/kkkkkkk/p‘ test.txt

已匹配字符串标记&
正则表达式 w+ 匹配每一个单词,使用 [&] 替换它,& 对应于之前所匹配到的单词:
echo this is a test line | sed ‘s/w+/[&]/g‘
[this] [is] [a] [test] [line]

数字匹配
将 TMOUT=$num 替换成 TMOUT=600 ($num由0-9的数字组成,+ 表示多位)
sed ‘s/TMOUT=[0-9]+/TMOUT=600/g‘ test.txt

子串匹配标记 1 ,匹配给定样式的其中一部分
将 TMOUT=$num 替换成 $num ,相当于去掉前面的“TMOUT=”。
sed ‘s/TMOUT=([0-9]+)/1/‘ test.txt
说明:(..) 用于匹配子串,1 表示匹配到的第一个子串,同理 2 表示第二个,如:
echo TMOUT=100 TMOUT=200|sed ‘s/TMOUT=([0-9]+) TMOUT=([0-9]+)/1 2/‘
输出结果为:100 200


查找
查找打印以keyword开头的行:
sed -n ‘/^keyword/p‘ test.txt

打印奇数行或偶数行
方法1:
sed -n ‘p;n‘ test.txt #奇数行
sed -n ‘n;p‘ test.txt #偶数行
方法2:
sed -n ‘1~2p‘ test.txt #奇数行
sed -n ‘2~2p‘ test.txt #偶数行

打印匹配字符串的下一行
grep -A 1 SCC URFILE
sed -n ‘/SCC/{n;p}‘ URFILE
awk ‘/SCC/{getline; print}‘ URFILE

从文件读入:r命令
file里的内容被读进来,显示在与test匹配的行后面,如果匹配多行,则file的内容将显示在所有匹配行的下面:
sed ‘/test/r file‘ test.txt

写入文件:w命令
在test.txt中所有包含test的行都被写入file里:
sed -n ‘/test/w file‘ test.txt


多点编辑:-e
-e选项允许在同一行里执行多条命令:
sed -e ‘1,5d‘ -e ‘s/test/check/‘ test.txt
上面sed表达式的第一条命令删除1至5行,第二条命令将test替换成check。

修改文件内容:-i直接修改文档的内容,不在屏幕上输出没有该参数时,sed命令只会输出其执行后的效果,不会真的修改文件,若要按照其执行效果修改文件,需要加 -i 参数:sed -i ‘s/keyword/kkkkkkk/g‘ test.txt

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读