每日一道shell练习(09)——sed处理

1. 习题

对一个文件,1至5行删除带有英文的行,6至10行删除里面的英文字符;shell

2. 分析

这种要求,用sed命令就能够解决了,主要用到匹配替换的知识。bash

3. 脚本

#!/bin/bash

sed  -n '1,5p'  a.txt  |  sed  '/[a-zA-Z]/d'
sed  -n '6,10p' a.txt  |  sed  's/[a-zA-Z]//g'
sed  -n '11,$p' a.txt

前两个要求,必须使用行号匹配。主要sed是一个流编辑处理器,它是一行一行地接收输入数据,而后再处理。ide

-n 和 -p 选项配合使用,就是只输出匹配的内容。因此,在前两行命令的意思就至关于,匹配到对应的行后,只处理这些行,而后经过管道,把它们传给后边的sed命令处理。code

第三行的sed命令,就是把不用处理的文本都直接输出屏幕。这样,在屏幕上看来,就至关于完整地处理了整个文本的内容了。it

相关文章
相关标签/搜索