用awk实现类似excel中vlookup函数的功能

由于excel中的vlookup函数的效率实在是太低了,哥们我做数据处理的,忍受不了了。
所以自己用脚本开发一个类似的功能。
代码如下:

vlookup.sh内容
#!/bin/csh

if [ $# -lt 4 ];
then
    echo "argument size < 4"
    echo "USEAGE sh vlookup.sh source.csv pattern.csv pattern_col output_col default_value"
    exit 0
fi

SOURCE_FILE=$1
PATTERN_FILE=$2
PATTERN_INDEX=$3
INSERT_INDEX=$4
DEFAULT_VALUE=$5

awk -v PATTERN_FILE=${PATTERN_FILE} -v PATTERN_INDEX=${PATTERN_INDEX} -v INSERT_INDEX=${INSERT_INDEX} -v DEFAULT_VALUE=${DEFAULT_VALUE} -F ',' -f vlookup.awk  ${SOURCE_FILE}




vlookup.awk文件内容:
#!/bin/awk -f
# 模仿excel中的vlookup函数的功能
# awk -v PATTERN_FILE=${PATTERN_FILE} -v PATTERN_INDEX=${PATTERN_INDEX} -v INSERT_INDEX=${INSERT_INDEX} -f vlookup.awk  ${SOURCE_FILE}

# 初始化
BEGIN{
    # 加载匹配文件
    while(getline < PATTERN_FILE){
        len=split($0 , pattern , ",") ;
        matcher = pattern[2] ;
        gsub(/\r/, "" , matcher) ;
        map[pattern[1]] = matcher ;
    }
    close(PATTERN_FILE) ;
}

# 行处理
{
    # 空行不进行处理
    if(NF == 0){
        next;
    }
    # 不处理第一行
    if(NR == 1){
       next ;
    }
    format = "" ;
    for(i = 1 ; i <= NF + 1 ; i ++){
        # 匹配到的行
        if(i == INSERT_INDEX){
            if($(PATTERN_INDEX) in map){
                format = format "" (map[$(PATTERN_INDEX)] "" ",") ;
            }else{
                format = format "" DEFAULT_VALUE "" ",";
            }
        }else{
            if(i < INSERT_INDEX){       # 直接输出的行
                gsub(/\r/, "", $i) ;
                format = format "" ($i "" ",") ;
            }else{              # 匹配的行的右边的列都向右移动
                gsub(/\r/, "", $(i-1)) ;
                format = format "" ($(i-1) "" ",") ;
            }
        }
    }
    printf("%s\n" , substr(format , 1 , length(format) - 1)) ;
}

#后处理
{
}


示例:
sh vlookup.sh area.csv pattern.csv 1 2 default_value

area.csv内容如下:
bianhongfei,10,hahaha,hahahah
bianhongfei,11,hahaha,hahahah
bianhongfei,12,hahaha,hahahah
bianhongfei,13,hahaha,hahahah
bianhongfei,14,hahaha,hahahah
bianhongfei,15,hahaha,hahahah
bianhongfei,16,hahaha,hahahah
bianhongfei,17,hahaha,hahahah
bianhongfei,18,hahaha,hahahah
bianhongfei,19,hahaha,hahahah
bianhongfei,20,hahaha,hahahah
bianhongfei,21,hahaha,hahahah
bianhongfei,22,hahaha,hahahah
bianhongfei,23,hahaha,hahahah
bianhongfei,24,hahaha,hahahah
bianhongfei,25,hahaha,hahahah
bianhongfei,26,hahaha,hahahah
bianhongfei,27,hahaha,hahahah
bianhongfei,28,hahaha,hahahah
bianhongfei,29,hahaha,hahahah
bianhongfei,30,hahaha,hahahah
bianhongfei,31,hahaha,hahahah
bianhongfei,32,hahaha,hahahah
bianhongfei,33,hahaha,hahahah
bianhongfei,34,hahaha,hahahah
bianhongfei,35,hahaha,hahahah
bianhongfei,36,hahaha,hahahah
bianhongfei,37,hahaha,hahahah
bianhongfei,38,hahaha,hahahah
bianhongfei,39,hahaha,hahahah
bianhongfei,40,hahaha,hahahah
bianhongfei,41,hahaha,hahahah
bianhongfei,42,hahaha,hahahah

pattern.csv的内容如下:
10,北京市
11,天津市
12,河北省
13,山西省
14,内蒙古自治区
15,辽宁省
16,吉林省
17,黑龙江省
18,上海市
19,江苏省
20,浙江省
21,安徽省
22,福建省
23,江西省
24,山东省
25,河南省
26,湖北省
27,湖南省
28,广东省
29,广西壮族自治区
30,海南省
31,重庆市
32,四川省
33,贵州省
34,云南省
35,西藏自治区
36,陕西省
37,甘肃省
38,青海省
39,宁夏回族自治区
40,新疆维吾尔自治区
41,港澳地区

参数:1,匹配第一列,2,输出在第二列



最终输出:
10,北京市,hahaha,hahahah
11,天津市,hahaha,hahahah
12,河北省,hahaha,hahahah
13,山西省,hahaha,hahahah
14,内蒙古自治区,hahaha,hahahah
15,辽宁省,hahaha,hahahah
16,吉林省,hahaha,hahahah
17,黑龙江省,hahaha,hahahah
18,上海市,hahaha,hahahah
19,江苏省,hahaha,hahahah
20,浙江省,hahaha,hahahah
21,安徽省,hahaha,hahahah
22,福建省,hahaha,hahahah
23,江西省,hahaha,hahahah
24,山东省,hahaha,hahahah
25,河南省,hahaha,hahahah
26,湖北省,hahaha,hahahah
27,湖南省,hahaha,hahahah
28,广东省,hahaha,hahahah
29,广西壮族自治区,hahaha,hahahah
30,海南省,hahaha,hahahah
31,重庆市,hahaha,hahahah
32,四川省,hahaha,hahahah
33,贵州省,hahaha,hahahah
34,云南省,hahaha,hahahah
35,西藏自治区,hahaha,hahahah
36,陕西省,hahaha,hahahah
37,甘肃省,hahaha,hahahah
38,青海省,hahaha,hahahah
39,宁夏回族自治区,hahaha,hahahah
40,新疆维吾尔自治区,hahaha,hahahah
41,港澳地区,hahaha,hahahah
42,default,hahaha,hahahah

编程技巧