[发明专利]基于Excel表的计算方法、装置、设备及存储介质在审
申请号: | 201711415048.9 | 申请日: | 2017-12-21 |
公开(公告)号: | CN108170638A | 公开(公告)日: | 2018-06-15 |
发明(设计)人: | 储斌 | 申请(专利权)人: | 平安科技(深圳)有限公司 |
主分类号: | G06F17/15 | 分类号: | G06F17/15;G06F8/41;G06F8/30 |
代理公司: | 深圳市世纪恒程知识产权代理事务所 44287 | 代理人: | 胡海国 |
地址: | 518000 广东省深*** | 国省代码: | 广东;44 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 目标计算 配置文件 预设 计算机可读存储介质 读取 存储介质 公式函数 获取目标 计算公式 计算过程 计算效率 计算指令 计算装置 运算规则 调用 集合 消耗 | ||
本发明公开了一种基于Excel表的计算方法,该方法包括:当接收到计算指令时,获取目标计算公式,将所述目标计算公式拆分为若干个子公式;读取Excel表的配置文件,按照预设的MAP集合类在所述配置文件中定位所述子公式中的Java对象,并获取所述Java对象的取值;按照预设的Excel宏的公式函数和Java方法之间的对应关系,调用所述子公式对应的Java方法,将所述Java对象的取值代入所述Java方法中进行计算,得到所述目标计算公式的计算结果,其中,所述Java方法用于表示基于所述Java对象的运算规则。本发明还公开了一种基于Excel表的计算装置、设备和一种计算机可读存储介质。本发明能够缩减Excel表计算过程中对内存的消耗,同时提高计算效率。
技术领域
本发明涉及计算机技术领域,尤其涉及基于Excel表的计算方法、装置、设备及存储介质。
背景技术
目前很多产品报价的计算是通过Excel表完成的,即首先将报价相关数据记录在Excel表中,然后通过Excel提供的运算功能自动计算报价。Excel表计算报价的方式一般为:首先通过poi(poi是一种强大的office操作组件,其提供应用程序编程接口给Java程序对Microsoft Office格式档案进行读和写的功能)解析Excel表,进而根据目标计算公式计算目标单元格的值。
上述计算过程会对Excel的单元格进行迭代,当报价计算公式很复杂时,上述计算过程会由此产生很多Java计算对象,产生的对象将大量占用内存,此时Java虚拟机的垃圾回收机制会不断扫描内存中可以回收的对象,而在计算结果出来前,这些计算的对象都是被引用的,无法进行回收,因此在内存中积压,很容易造成系统宕机,且导致计算效率低下。
发明内容
本发明的主要目的在于提出一种基于Excel表的计算方法、装置、设备及计算机可读存储介质,旨在缩减Excel表计算过程中对内存的消耗,同时提高计算效率。
为实现上述目的,本发明提供一种基于Excel表的计算方法,所述方法包括如下步骤:
当接收到计算指令时,获取目标计算公式,将所述目标计算公式拆分为若干个子公式;
读取Excel表的配置文件,按照预设的MAP集合类在所述配置文件中定位所述子公式中的Java对象,并获取所述Java对象的取值;
按照预设的Excel宏的公式函数和Java方法之间的对应关系,调用所述子公式对应的Java方法,将所述Java对象的取值代入所述Java方法中进行计算,得到所述目标计算公式的计算结果,其中,所述Java方法用于表示基于所述Java对象的运算规则。
优选地,所述当接收到计算指令时,获取目标计算公式,将所述目标计算公式拆分为若干个子公式的步骤之前,还包括:
获取Excel宏的公式函数,将所述公式函数编译为对应的Java方法;
建立所述公式函数和所述Java方法之间的对应关系。
优选地,所述读取Excel表的配置文件,按照预设的MAP集合类在所述配置文件中定位所述子公式中的Java对象,并获取所述Java对象的取值的步骤包括:
读取Excel表的配置文件,识别所述配置文件中用于标识Excel单元格的标签;
将所述标签转换为预设的MAP集合类中定义的键值;
按照预设的键值和Java对象之间的对应关系,将所述子公式中的Java对象转换为对应的键值;
将由所述标签转换得到的所述键值与由所述Java对象转换得到的所述键值进行匹配,得到所述配置文件中与所述Java对象对应的Excel单元格,将所述Excel单元格的取值作为所述Java对象的取值。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于平安科技(深圳)有限公司,未经平安科技(深圳)有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201711415048.9/2.html,转载请声明来源钻瓜专利网。