首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >匹配模式并以匹配的字符串追加每行

匹配模式并以匹配的字符串追加每行
EN

Stack Overflow用户
提问于 2014-07-14 19:02:47
回答 2查看 59关注 0票数 0

匹配模式并以匹配的字符串追加每一行,直到下一次匹配为止。WES和GET2在下面的示例中是匹配的:我知道如何使用一种模式

代码语言:javascript
复制
awk '$1~/WES/{A=$1}{print A,$0}'

但不知道如何处理两种模式:

输入:

代码语言:javascript
复制
WES S1 S2 SET3
S2 S4 S5
D3 D7 F2
GET2 F4 S3 64
SES2 32 Q3
Y67 98 GT1
WES S2 S4 SET3
S2 S4 S5
D3 D7 F2

输出:

代码语言:javascript
复制
WES WES S1 S2 SET3
WES S2 S4 S5
WES D3 D7 F2
GET2 GET2 F4 S3 64
GET2 SES2 32 Q3
GET2 Y67 98 GT1
WES WES S2 S4 SET3
WES S2 S4 S5
WES D3 D7 F2
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-07-14 20:30:07

代码语言:javascript
复制
$ awk 'match($1,/WES|GET2/){A=substr($1,RSTART,RLENGTH)} {print A,$0}' file
WES WES S1 S2 SET3
WES S2 S4 S5
WES D3 D7 F2
GET2 GET2 F4 S3 64
GET2 SES2 32 Q3
GET2 Y67 98 GT1
WES WES S2 S4 SET3
WES S2 S4 S5
WES D3 D7 F2

顺便说一句,在前面附加文本是prepending,而不是appending,因为它是附加到末尾的。

票数 0
EN

Stack Overflow用户

发布于 2014-07-14 21:13:24

代码语言:javascript
复制
awk '$1 ~ /^(WES|GET2)$/{ p = $1 FS }{ print p $0 }' file.txt

输出:

代码语言:javascript
复制
WES WES S1 S2 SET3
WES S2 S4 S5
WES D3 D7 F2
GET2 GET2 F4 S3 64
GET2 SES2 32 Q3
GET2 Y67 98 GT1
WES WES S2 S4 SET3
WES S2 S4 S5
WES D3 D7 F2

其他变动:

代码语言:javascript
复制
awk '$1 ~ /^(WES|GET2)$/{ p = $1 }{ print p FS $0 }' file.txt
awk '$1 ~ /^(WES|GET2)$/{ p = FS $1 }{ $0 = p $0 } 1' file.txt
awk '$1 ~ /^(WES|GET2)$/{ p = $1 }{ $0 = p FS $0 } 1' file.txt
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24743857

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档