发新话题
打印

awk去掉删除最后一列

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

原文:https://blog.csdn.net/ANLJF/article/details/7082116

TOP

发新话题