sed常用用法技巧举例

1.sed替换换行符及标签的使用

echo "a,b,c,d" |sed ‘s/,/\n/g‘|sed ‘s/\n/,/g‘

解析:以上命令实现不了替换换行符,这跟sed的行处理方式有关,sed读取一行时,会先把换行符去掉,处理完后再添加上,所以是无法使用上面的命令进行换行符替换的,必须使用sed中的其它命令来完成。上面的恢复可以使用tr命令:

echo "a,b,c,d" |sed ‘s/,/\n/g‘|tr -t ‘\n‘ ‘,‘

以下命令能实现替换文本中全部换行符:

sed ‘:label;N;s/\n/:/;b label‘ filename
sed ‘:label;N;s/\n/:/;t label‘ filename

解析:

:label;  这是一个标签,用来实现跳转处理,名字可以随便取(label),后面的b label就是跳转指令

N;  N是sed的一个处理命令,追加文本流中的下一行到模式空间进行合并处理,因此是换行符可见

s/\n/:/;   s是sed的替换命令,将换行符替换为冒号

b label  或者 t label    b / t 是sed的跳转命令,跳转到指定的标签处

2.sed输出奇数行和偶数行

a.

sed -n ‘p;n‘ file    #奇数行
sed -n ‘n;p‘ file    #偶数行

解析:n表示读取下一个输入行,用下一个命令处理新的行而不是第一个命令。

b.

sed -n ‘1~2p‘ file    #奇数行
sed -n ‘2~2p‘ file    #偶数行

解析:第一个数字表示起始行,第二个数字表示步长。

参考资料:

http://my.oschina.net/shelllife/blog/118337

时间: 2024-10-05 13:20:05

sed常用用法技巧举例的相关文章

awk常用用法技巧举例

1.awk中的!a[$0]++与!a[$1]++的使用 !a[$0]++可以去除一行中重复的记录,例子如下: [[email protected] shell]# cat 1.txt  a a b b c c e f g a f [[email protected] shell]# awk '!a[$0]++' 1.txt  a b c e f g 解释:a[$0]就是以每一行内容为索引的一个hash表,当a[$0]未声明时,a[$0]为假,在未声明的情况下,进行一次a[$0]++后,a[$0]

linux sed常用用法总结

sed是linux中比较常用的文本编辑类命令,规则为逐行输出 其比较常用的用法如下: sed [OPTION] {SCRIPT} FILENAME 主要[OPTION]: -n:不再显示默认模式空间中的内容 -i:修改源文件 -e:同时执行多个操作 例如:sed -e {SCRIPT} -e {SCRIPT} ... -f:指定脚本文件处理文本内容 例如:sed -f SCRIPTNAME FILENAME -r:允许使用扩展的正则表达式(同grep -e 或者 egrep) {SCRIPT}可

sed常用用法总结

sed是Stream EDitor流编辑器的缩写,是GNU的软件项目,项目地址http://www.gnu.org/software/sed/ , 和grep,awk一起为视为linux下文字处理三大神器. sed的工作原理:简单的讲就是读取一行到内存,处理完再读取下一行,一直到最后一行. 稍微详细一点讲就是读取一行放到模式空间(sed在内存申请的一段内存空间),被模式匹配到则按给定的Action处理,处理完则继续读入下一行,如果没有被模式匹配到则直接继续进入下一步.如果没有给模式则默认是空模式

sed基本用法

Sed是行处理命令,处理的过程是逐行将需要处理数据读入到模式空间处理,处理完成打印(默认)模式空间内容并清空模式空间,所以除非是添加特殊参数(-i),否则sed是不会修改文本内容,参数(-n)是不打印缓存空间内容,其他参数内容见下列表 常用选项 命令 功能 -n 屏蔽模式空间的自动打印,否则每行处理结束会自动打印 -i 在适当的位置修改文件(直接在文件中修改,慎用!!!) -r 使用扩展正则表达式 -e 多项操作 -f 添加脚本文件内容到命令 定址查找 Shell> Seq 3| sed –n

linux常用命令技巧

原文地址 这篇文章来源于Quroa的一个问答<What are some time-saving tips that every Linux user should know?>-- Linux用户有哪些应该知道的提高效率的技巧.我觉得挺好的,总结得比较好,把其转过来,并加了一些自己的理解. 首先,我想告诉大家,在Unix/Linux下,最有效率技巧的不是操作图形界面,而是命令行操作,因为命令行意味着自动化.如果你看过<你可能不知道的Shell>以及<28个Unix/Linu

linux中sed的用法

sed命令行格式为:         sed [-nefri]  'command'  输入文本/文件 常用选项:        -n∶取消默认的输出,使用安静(silent)模式.在一般 sed 的用法中,所有来自 STDIN的资料一般都会被列出到屏幕上.但如果加上 -n 参数后,则只有经过sed 特殊处理的那一行(或者动作)才会被列出来        -e∶进行多项编辑,即对输入行应用多条sed命令时使用. 直接在指令列模式上进行 sed 的动作编辑        -f∶指定sed脚本的文件

sed简单用法

-n∶取消默认的输出,使用安静(silent)模式.在一般 sed 的用法中,所有来自 STDIN的资料一般都会被列出到屏幕上.但如果加上 -n 参数后,则只有经过sed 特殊处理的那一行(或者动作)才会被列出来 -e∶进行多项编辑,即对输入行应用多条sed命令时使用. 直接在指令列模式上进行 sed 的动作编辑 -f∶指定sed脚本的文件名. 直接将 sed 的动作写在一个档案内, -f filename 则可以执行 filename 内的sed 动作 -r∶sed 的动作支援的是延伸型正则表

linux之sed的用法

sed是一个很好的文件处理工具,本身是一个管道命令,主要是以行为单位进行处理,可以将数据行进行替换.删除.新增.选取等特定工作,下面先了解一下sed的用法sed命令行格式为:         sed [-nefri] 'command' filename 常用选项:        -n:使用安静(silent)模式.在一般 sed 的用法中,所有来自 STDIN的资料一般都会被列出到萤幕上. 但如果加上 -n 参数后,则只有经过sed 特殊处理的那一行(或者动作)才会被列出来.        -

linux常用的技巧

在linux下使用shell时,我们常遇到这样的情况,即:前面所输入的所有命令需要重新做一遍,这时候在一条一条输就会觉得很麻烦,而且以后很可能这些命令还得重新执行一遍.这时,如果把shell下的history中的命令提取出来就好了,放到一个shell脚本中,就可以方便我们以后使用了. 但是,history下的文件格式往往是每条命令前都加了数字编号,如何去除呢?可以直接使用下面的命令: history |sed -e 's/^\s*[0-9]*\s*//g' 得出的结果就是所有命令的集合,可以直接