通过集算器将excel数据按列合并

来源:互联网 发布:mmd走路动作数据下载 编辑:程序博客网 时间:2024/06/06 03:18

客户数据存在多个excel中,格式如下:

多个excel中前两列相同,第三列后是按照地区存储数据,但是不同的excel中地区可能不能,比如第一个excel中有上海,第二个中没有,现在要求将数据合并,如果多个excel中都有北京,则将北京的数据求和,最后形成一个单独的excel,里边是各个excel数据的汇总。

实现方法:

在集算器中先构造一个比较全的序列,也就是最终excel中的地区的和,根据它进行各个excel的判断,如果包含则进行求和,集算器中有个函数eval,里边的参数是一个字符串,执行时会解析里边的字符串,然后再对字符串里的内容计算表达式,所以可以先拼成一个字符串,然后eval一下即可:

脚本如下:

脚本文本如下:

=file("D:\\a.xlsx")                                                           

=A1.importxls@tx(;"sheet1") =A1.importxls@tx(;"sheet2") =A1.importxls@tx(;"sheet3")                                     

[北京,上海,天津,河北,广州,河南,湖南,湖北]                                                              

=A2.fname()     =B2.fname()     =C2.fname()                                         

for A3                                                              

                   =if(A4.pos(A5)==null,"",if(B6==null,B6=B6+"t1."+A5,B6=B6+",t1."+A5))         =if(B4.pos(A5)==null,"",if(B6==null,B6=B6+"t2."+A5,B6=B6+"+t2."+A5))         =if(C4.pos(A5)==null,"",if(B6==null,B6=B6+"t3."+A5,B6=B6+"+t3."+A5))     >B6=B6+":"+A5+if(A3.pos(A5)==A3.len(),"",",")         >B1=B1+B6      >B6=null

                                                                

=join(A2:t1,系统编码;B2:t2,系统编码;C2:t3,系统编码)                                                              

="A8.new("+B1+")"                                                                 

=eval(A9)                                                        

 

执行结果:

 

0 0