ICode9

精准搜索请尝试: 精确搜索
首页 > 系统相关> 文章详细

Linux sed命令

2019-03-29 11:52:32  阅读:265  来源: 互联网

标签:匹配 keyword 命令 TMOUT sed Linux test txt


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 '2a\test line' test.txt

在第二行上面插入“test line”
sed '2i\test line' test.txt

在keyword开头的行下面插入“test line”
sed '/^keyword/a\test line' test.txt

在keyword开头的行上面插入“test line”
sed '/^keyword/i\test 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。

标签:匹配,keyword,命令,TMOUT,sed,Linux,test,txt
来源: https://www.cnblogs.com/pccnng/p/10588478.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有