Chinaunix首页 | 论坛 | 博客
  • 博客访问: 3032008
  • 博文数量: 272
  • 博客积分: 5544
  • 博客等级: 大校
  • 技术积分: 5496
  • 用 户 组: 普通用户
  • 注册时间: 2011-03-08 00:48
个人简介

  每个人都要有一个骨灰级的爱好,不为金钱,而纯粹是为了在这个领域享受追寻真理的快乐。

文章分类

全部博文(272)

文章存档

2015年(2)

2014年(5)

2013年(25)

2012年(58)

2011年(182)

分类: LINUX

2011-05-14 14:40:59

文本:

12 34 56
78 90 12
23 45 89

要求对最后一个域进行排序:
78 90 12
12 34 56
23 45 89

 

  1. awk '{a[$NF]=$0}END{l=asorti(a,b);for(i=1;i<=l;i++)print a[b[i]]}' file

[解析]

  首先明白按最后一个域排序,即把最后一个域做为下标,把该行的值存入数组a,本案文本是3行,执行完后得到如下内容:

  a[56]=12 34 56

  a[12]=78 90 12

  a[89]=23 45 89

END,在最后执行命令,asorti对数组a的下标进行排序,并把排序后的下标存入新生成的数组b中,并把数组a的长度赋值给变量l。然后必须用for循环取出数组的下标,因为数组是无法直接print打印的,这时候打印输出变量i,排序后的数字b的下标的值,然后把该下标在数组a中的赋值打印出来。

内置函数asort只对值进行排序,会丢掉原来的数组值。

  1. awk '{a[$1]}END{print asorti(a)}' file
  2. awk '{a[$1]}END{print length(a)}' file

统计下标的数量,并打印。

阅读(2181) | 评论(1) | 转发(0) |
给主人留下些什么吧!~~

chaseey2012-08-22 21:42:02

将a[$NF]=$0 觉得有点不妥
如以下数据
12 34 56
78 90 12
23 45 12
会有两个a[12]出现,覆盖掉一个吧