客户数据存在多个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)
执行结果: