awk删除文件最后一列


使用awk删除用特定分隔符分割的文件的最后一列

该文件以“:”分隔符

绿色标识的为文件的最后一列

[root@localhost zhaoyj]#cat file.txt

Mike Harrington:[510] 548-1278:250:100 :25
Christian Dobbins:[408] 538-2358:155:90 :78
Susan Dalsass:[206] 654-6279:250:60 :49
Archie McNichol:[206] 548-1348:250:100 :200


如果我直接将最后一列用空字符替换,最后一个分隔符还是存在的

注意这里需要指定输出分隔符OFS,否则执行完命令以后输出分隔符就成为了空格

这个跟$0重组有关系,不明白的童鞋可以参考之前的文章“GNU awk的$1=$1到底有什么作用?$0=$0呢?

[root@localhost zhaoyj]# awk -F: 'OFS=":"{$NF="";print}' file.txt

Mike Harrington:[510] 548-1278:250:100:
Christian Dobbins:[408] 538-2358:155:90:
Susan Dalsass:[206] 654-6279:250:60:

Archie McNichol:[206] 548-1348:250:100:


删除最后一个分割符

[root@localhost zhaoyj]# awk -F: 'OFS=":"{$NF="";print}' file.txt |sed 's/:$//g'
Mike Harrington:[510] 548-1278:250:100
Christian Dobbins:[408] 538-2358:155:90
Susan Dalsass:[206] 654-6279:250:60

Archie McNichol:[206] 548-1348:250:100


如果文件是以空格为分隔的话就简单了直接这样就可以了

awk  '{$NF="";print}' file.txt


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值