awk删除文件最后一列

时间:2021-07-12 10:08:13


使用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