首页 > 其他 > 详细

如何把大 Excel 文件拆成多个小文件

时间:2020-06-12 14:33:47      阅读:48      评论:0      收藏:0      [点我收藏+]

出于各种原因,有时我们要将一个大Excel拆成一些小文件。这种算法可以用VBA实现,但代码很非常难写,还容易发生内存溢出。

用esProc就简单多了,比如把大文件拆成每1500行一个的小文件,只有这么几行:

  A B D
1 =file("dt.xlsx").xlsimport@t() /打开Excel,假定第一行是标题
2 for A1.group((#-1)\1500)   /循环取数,每次1500行
3   =file(#A2/".xlsx").xlsexport(A2) /生成小Excel,文件名为循环数

有时还可能按列分组来拆分,比如Excel首行标题为col1、col2…,且已按col1排序(可以事先在Excel中排好),我们要根据col1拆分成多个Excel。代码也很简单:

  A B D
1 =file("dt.xlsx").xlsimport@t()  
2 for A1.group(col1)   /按col1分组循环
3   =file(A2.col1/".xlsx").xlsexport@t(A2) /小文件名为分组名

把前面两个要求合并起来也很简单(即按col1分组,但子文件最多1500行):

  A B C D
1 =file("dt.xlsx").xlsimport@t()    
2 for A1.group(col1)     /按col1分组循环
3   for A2.group((#-1)\1500)   /再每次循环取1500条
4     =file(B3.col1/#B3/".xlsx").xlsexport@t(B3) /小文件名为分组名+循环次数

esProc是个脚本语言,可以在桌面IDE里执行,数据以表格呈现,调试这种带循环的算法很方便。

类似的Excel计算的例子(含超出内存的大Excel):

SPL 解析及导出 Excel SPL 解析及导出 Excel
excel 合并汇总 excel 合并汇总

文本文件和 Excel 在 esProc 里处理方式相同,很多算法可以互相参考:
SPL 结构化文本计算 SPL 结构化文本计算

esProc 是专业的文件处理脚本,即安即用,调试方便,类库丰富,详情参考 http://www.raqsoft.com.cn/wx/file-processor.html
关于集算器安装使用、获得免费授权和相关技术资料,可以参见 如何使用集算器?

如何把大 Excel 文件拆成多个小文件

原文:https://www.cnblogs.com/xiaohuihui-11/p/13098584.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!