现在的位置: 首页 > 综合 > 正文

awk消除重复代码的方案1

2012年08月31日 ⁄ 综合 ⁄ 共 763字 ⁄ 字号 评论关闭

 

#!/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的类库设计,就知道自己把类设计成什么样了。。。

 

 

抱歉!评论已关闭.