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