Linux去除重复列(awk之数组妙用)

命令参数

系统环境:CentOS 6.2 i686

有文件,包含的内容如下:

去除重复列结果如下:

方法:file

循环取出下标,用split(j,b,SUBSEP)将两个下标分离赋值给新的数组b,此时b[1]中的数据就是我们想要的(不重复的列),,最后判断b[2]与行号相等的则打印b[1]。执行命令后结果如下:

如果只想打印重复列,只需a数组的之是否大于1:

执行结果如下:

补充:

awk的二维数组使用

awk的多维数组在本质上是一维数组,更确切一点,awk在存储上并不支持多维数组。awk提供了逻辑上模拟二维数组的访问方式。例如,array[2,4] = 1这样的访问是允许的。awk使用一个特殊的字符串SUBSEP (\034)作为分割字段,在上面的例子中,关联数组array存储的键值实际上是2\0344。类似一维数组的成员测试,多维数组可以使用 if ( (i,j) in array)这样的语法,但是下标必须放置在圆括号中。类似一维数组的循环访问,多维数组使用 for ( item in array )这样的语法遍历数组。与一维数组不同的是,多维数组必须使用split()函数来访问单独的下标分量。split ( item, subscr, SUBSEP)。

可以提高你的水平。(戏从对手来。

Linux去除重复列(awk之数组妙用)

相关文章:

你感兴趣的文章:

标签云: