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

客户数据存在多个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
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值