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