您的位置:首页 > 其它

awk删除文件最后一列

2011-12-18 19:26 92 查看
使用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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: