加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Linux > 正文

sed – 从文件中提取数据

发布时间:2020-12-14 00:33:11 所属栏目:Linux 来源:网络整理
导读:我有一个文件results.txt,如: a.txt{some data}success!!b.txt{some data}success!!c.txt{some data}error!! 我想从中提取数据.我想要一个输出: a.txt: successb.txt: successc.txt: error 问题是{some data}部分可以任意长. 如何才能做到这一点? 解决方
我有一个文件results.txt,如:

a.txt
{some data}
success!!

b.txt
{some data}
success!!

c.txt
{some data}
error!!

我想从中提取数据.我想要一个输出:

a.txt: success
b.txt: success
c.txt: error

问题是{some data}部分可以任意长.

如何才能做到这一点?

解决方法

$cat file
a.txt
{some
  blah
data}
success!!

b.txt
{some data}
success!!

c.txt
{some data}
error!!

$awk 'BEGIN{ FS="[{}]|n";RS=""}{gsub(/!!/,"",$NF);print $1":"$NF}' file
a.txt:success
b.txt:success
c.txt:error

更新:

$awk -vRS= -vFS="n" '{print $1":"$NF}' file
a.txt:success!!
b.txt:success!!
c.txt:error!!

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读