awk消除重复代码的方案1

 

#!/bin/sh



awk '



function createArray(filename,arrayname)

{

    while(getline<filename == 1)#等于1的判断是必须的,否则文件不存在会产生死循环

    {

        arrayname[$1] = $2

        print arrayname[$1]

    }

    print ""

}



END{

    createArray("aaa.txt",a);

    createArray("bbb.txt",b);



    print "output content of aaa.txt"

    for(i in a)

    {

        print i" "a[i]    

    }



    print "output content of bbb.txt"

    for(j in b)

    {

        print j" "b[j]

    }

}

' aaa

之前维护(自己也写了一些)shell + awk的程序,最让自己恶心的是程序里有大量的重复代码,这些代码要从某些文件里读取数据成为数组(文件结构也很类似,就是2列的N行的文本文件,很像excel里的行列含义)结果硬生生的产生了大量的重复代码,我试图把这些代码放入到函数里,希望把数组return出来(这是类C语言里很常见的写法)结果awk里就是不行,龌蹉到家里,今天突然想到,系统自己的一个自带函数是可以返回数组的,那就是split函数

#切割以逗号分隔的字符串成为数组

names = "book_id,chap_id,price"

split(names,nameArray,",")

for(i in nameArray)

{

    print nameArray[i] 

}

试了一下,果然是可以的,系统的API也是通过参数名返回的值,意思就是说:这是按引用传参。。这事给我一个很大的启发,当对某个东西想不清楚时不妨参考一下系统的设计,其实这是也是牛头原来和我说的,可以看看.NET的类库设计,就知道自己把类设计成什么样了。。。

 

 

你可能感兴趣的:(awk)