Linux sed 命令

Linux sed 命令

简介

sed 命令是一个面向行处理的工具,它以“行”为处理单位,针对每一行进行处理,处理后的结果会输出到标准输出(STDOUT), 多用于脚本文件中需要处理文件。

语法

sed [OPTION] {script-only-if-no-other-script} [input-file]
sed 参数 动作 文件

参数说明

  • -e
#在第一行下插入123
sed -e 1a\ 123 test.txt 
sed 1a\ 123 test.txt 
  • -f <script文件>,–file=<script文件> 以选项中指定的<script文件>(脚本)来处理输入的文本文件。

  • -h,–help 查看帮助
#查看sed命令帮助
sed -h
sed --help
  • -n,–quite,–silent仅显示处理后的结果
#只打印出,把文件中的123替换成555的行
sed -n 's/123/555/p' test.txt
  • –version显示版本
sed --version
  • -i,–in-place直接修改文件内容
#在文件中第一行后面加入qwe
sed -i 1a\ qwe test.txt
  • -r,–regexp-extended支持 扩展表达式;

动作说明

a\ 在当前行下面插入文本;

i\ 在当前行上面插入文本;

c\ 把选定的行改为新的文本;

s\ 替换指定字符;

d\ 删除选择的行;

h 拷贝模板块的内容到内存中的缓冲区;

H 追加模板块的内容到内存中的缓冲区;

g 获得内存缓冲区的内容,并替代当前模板块中的文本;

G 获得内存缓冲区的内容,并追加到当前模板块文本的后面;

l 列表不能打印字符的清单;

n 读取下一个输入行 ,用下一个命令处理新的行而不是用第一个命令;

N 追加下一个输入行到模板块后面并在二者间嵌入一个新行,改变当前行号码;

p 打印模板块的行。

P 打印模板块的第一行;

q 退出Sed;

b lable 分支到脚本中带有标记的地方,如果分支不存在则分支到脚本的末尾;

r file从file中读行;

t label if分支,从最后一行开始,条件一旦满足或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾;

T label错误分支,从最后一行开始,一旦发生错误或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾;

w file写并追加模板块到file末尾;

W file写并追加模板块的第一行到file末尾;

! 表示后面的命令对所有没有被选定的行发生作用;

= 打印当前行号;

# 把注释扩展到下一个换行符以前;

元字符集

^ 匹配行开始,如:/^sed/匹配所有以sed开头的行;

$ 匹配行结束,如:/sed$/匹配所有以sed结尾的行;

. 匹配一个非换行符的任意字符,如:/s.d/匹配s后接一个任意字符,最后是d;

* 匹配0个或多个字符,如:/*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结尾的单词的行;

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的行;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值