sed 学习笔记(转)

声明:这些代码只是为了学习和理解sed命令而为之,并不代表问题的唯一解或最佳解,希望各位拍砖

参考资料:等

一. 替换

1.神奇变换(y命令的使用)

代码:

sed 'y/ori_letter_list/target_letter_list/' filename

代码:

cat filename

1234567890

2345678901

3456789012

4567890123

测试

将文件中1换成A

将文件中2换成B

...

将文件中0换成J

代码:

sed 'y/1234567890/ABCDEFGHIJ/' filename

ABCDEFGHIJ

BCDEFGHIJA

CDEFGHIJAB

DEFGHIJABC

注意变换关系是按两个list的位置对应变换,y是一个管局命令,拒绝使用后缀flag/g

list1:1234567890

list2:ABCDEFGHIJ

下面再作一个与前例相反的变换

代码:

sed 'y/0987654321/ABCDEFGHIJ/' filename

JIHGFEDCBA

IHGFEDCBAJ

HGFEDCBAJI

GFEDCBAJIH

2.替换每行第一个匹配

代码:

sed 's/regexpr/anyword/' filename

sed 's/regexpr/anyword/1' filename

举例:

引用:

cat filename

1234567890 2345678901

3456789012 4567890123

sed 's/5/五/' filename

1234五67890 2345678901

34五6789012 4567890123

3.替换每行第n(如果有的话)个匹配

代码:

sed "s/regexpr/anyword/${n}" filename

cat filename

111111111111111111

222222222222222222

333333333333333333

444444444444444444

举例

sed "s/4/ 四 /8" filename

111111111111111111

222222222222222222

333333333333333333

4444444 四 4444444444

4.替换每行所有匹配

代码:

cat filename

1234567890 2345678901

3456789012 4567890123

代码:

举例:

sed 's/3/三/g' filename

12三4567890 2三45678901

三456789012 456789012三

二.行号处理

1.为文件加行号

代码:

sed = filename|sed 'N;s/\n/:/'

cat filename

111111111111111111

222222222222222222

333333333333333333

444444444444444444

举例

代码:

sed = filename|sed 'N;s/\n/:/' filename

1:111111111111111111

2:222222222222222222

3:333333333333333333

4:444444444444444444

2.仅为文件中的正文行加行号

代码:

sed /./= a|sed '/./N;s/\n/:/'

举例

代码:

cat filename

111111111111111111

222222222222222222

333333333333333333

444444444444444444

sed /./= a|sed '/./N;s/\n/:/' filename

1:111111111111111111

3:222222222222222222

4:333333333333333333

6:444444444444444444

三.字串翻转

代码:

sed '/\n/!G;s/\(.\)\(.*\n\)/&\2\1/;//D;s/.//'

举例

代码:

echo 1234567890|sed '/\n/!G;s/\(.\)\(.*\n\)/&\2\1/;//D;s/.//'

0987654321

四.选择性输出

1.打印文档奇数行(隔行输出)

代码:

sed 'n;d'

sed 'x;$!N;x'

sed -n 'p;n'

1

3

5

7

2.打印偶数行(隔行输出)

代码:

sed -n 'n;p'

sed '1d;n;d;'

2

4

6

8

3.删除连续重复行(大量使用了pattern space 文件太大时要注意)

代码:

sed '$!N; /^\(.*\)\n\1$/!P; D'

#使用 $!N 要当心内存溢出

举例

代码:

cat file

111111111111111111

222222222222222222

222222222222222222

333333333333333333

444444444444444444

444444444444444444

444444444444444444

444444444444444444

444444444444444444

sed '$!N; /^\(.*\)\n\1$/!P; D' filename

111111111111111111

222222222222222222

333333333333333333

444444444444444444

4.合并上下行并以空格相分隔

代码:

sed '$!N;s/\n/ /'

举例

代码:

cat file

1234567890

0987654321

执行命令后

1234567890 0987654321

5.将以\符号结尾的行与下行合并并以空格分隔(拼接断行)

代码:

sed -e :a -e '/\\$/N; s/\\\n/ /; ta'

举例

代码:

cat filename

1 111111111111111111\

2 222222222222222222

3 333333333333333333\

4 444444444444444444

sed -e :a -e '/\\$/N; s/\\\n/ /; ta' filename

1 111111111111111111 2 222222222222222222

3 333333333333333333 4 444444444444444444

6.按关键字拼接行

如果某行以=开始,则合并到上一行并替代=为空格

代码:

sed -e :a -e '$!N;s/\n=/ /;ta' -e 'P;D'

举例

代码:

cat file

111111111111111111

222222222222222222

=333333333333333333

444444444444444444

sed -e :a -e '$!N;s/\n=/ /;ta' -e 'P;D' filename

111111111111111111

222222222222222222 333333333333333333

444444444444444444

7.输出匹配行的下一行

代码:

sed -n '/regexpr/{n;p;}' filename

举例

代码:

cat filename

1 111111111111111111

2 222222222222222222

3 333333333333333333

4 444444444444444444

sed -n '/^3/{n;p;}' filename

4 444444444444444444

8.显示匹配行的行号并输出匹配行的上行、匹配行、下行

sed -n -e '/regexpr/{=;x;1!p;g;$!N;p;D;}' -e h

举例

代码:

cat filename

1 111111111111111111

2 222222222222222222

3 333333333333333333

4 444444444444444444

sed -n -e '/^3/{=;x;1!p;g;$!N;p;D;}' -e h filename

3 #匹配行的行号

2 222222222222222222 #上一行

3 333333333333333333 #匹配行

4 444444444444444444 #下一行

9.删除文档中某标志区域内的关键字匹配行

删除文档中从being开到end结束的块中包含myword的行

代码:

sed '/^begin/,/^end/{/myword/d;}' filename

引用:

cat filename

myword

begin

myword

Number!

myword

Number!

myword

Number!

myword

Number!

end

myword

Number!

测试

引用:

myword

begin

Number!

Number!

Number!

Number!

end

myword

Number!

五.字串解析

1.从字串中解析出两个子串(前2各字符和后9个字符)

代码:

echo "WeLoveChinaUnix"|sed -e 'H;s/\(..\).*/\1/;x;s/.*\(.\{9\}\)$/\1/;x;G;s/\n/ /'

We ChinaUnix

2.分解日期串

代码:

echo 20030922|sed 's/\(....\)\(..\)\(..\)/\1 \2 \3/'|read year month day

echo $year $month $day

2003 09 22

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏申龙斌的程序人生

Eclipse油藏模型解析程序

2010年的时候,三维可视化项目中要读取eclipse建模软件产生的三维模型网格数据,经过连续多天的奋战,终于搞明白eclipse数模软件输出的egrid、in...

38870
来自专栏Redis源码学习系列

Redis源码学习之字典

在字典结构体中,包含了一组字典函数(dictType),通过封装的方法处理对应的操作,通常在字典初始化的时候对其进行配置。

43110
来自专栏Golang语言社区

使用 Go 语言学会 Tensorflow

Tensorflow 并不是一个专门用于机器学习的库,相反的,它是一个通用的用于图计算的库。它的核心部分是用 C++ 实现的,同时还有其它语言的接口库。Go 语...

54820
来自专栏李海辰的专栏

Unity引擎资源管理代码分析 ( 2 )

上一篇《Unity 引擎资源管理代码分析 ( 1 ) 》讲解了 Unity 引擎资源管理代码的类型设计架构和 Resources.Load 接口的实现,本文将...

1.1K40
来自专栏开发与安全

从零开始学C++之虚继承和虚函数对C++对象内存模型造成的影响(类/对象的大小)

首先重新回顾一下关于类/对象大小的计算原则: 类大小计算遵循结构体对齐原则 第一个数据成员放在offset为0的位置 其它成员对齐至min(sizeof(me...

25000
来自专栏debugeeker的专栏

《coredump问题原理探究》Linux x86版5.7节C风格数据结构内存布局之结构体数组

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/xuzhina/article/detai...

9310
来自专栏用户2442861的专栏

限制QLineEdit的数值输入范围

QLineEdit *lineEdit = new QLineEdit(this);

2.2K10
来自专栏机器人网

只会G代码不会宏,就别说你是数控师傅

一、变量 普通加工程序直接用数值指定G代码和移动距离;例如,GO1和X100.0。使用用户宏程序时,数值可以直接指定或用变量指定。当用变量时,变量值可用程序或用...

29840
来自专栏SDNLAB

Open vSwitch系列之数据结构解析深入分析ofpbuf

上一篇我们分析了hmap,hamp可以说是Open vSwitch中基石结构,很多Open vSwitch中数据结构都依赖hmap。本篇我们来分析一下ofpbu...

40080
来自专栏大闲人柴毛毛

Redis源码分析(三)——Redis数据结构-字典

1. 数据结构 ? 1.1 哈希表 typedef struct dictht{ dictEntry **table; unsigned long s...

32050

扫码关注云+社区

领取腾讯云代金券