[发明专利]一种多级标题的Excel表单生成方法及装置在审
申请号: | 202210874859.X | 申请日: | 2022-07-25 |
公开(公告)号: | CN115130447A | 公开(公告)日: | 2022-09-30 |
发明(设计)人: | 朱晓峰;黄峰 | 申请(专利权)人: | 中银金融科技有限公司 |
主分类号: | G06F40/18 | 分类号: | G06F40/18;G06F16/242 |
代理公司: | 北京集佳知识产权代理有限公司 11227 | 代理人: | 张静 |
地址: | 200120 上海市中国(上海*** | 国省代码: | 上海;31 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 多级 标题 excel 表单 生成 方法 装置 | ||
本发明提供了一种多级标题的Excel表单生成方法及装置,可应用于金融领域或其他领域,通过预先配置表单模板,在接收到表单生成指令的情况下,就可以通过解析表单模板,得到表单的多级标题中每个标题在Excel中的位置以及表单列与SQL语句中字段的映射关系,进而根据表单的多级标题中每个标题在Excel中的位置,绘制表单的多级标题,将动态参数值代入SQL语句后执行SQL语句,依据表单列与SQL语句中字段的映射关系,将执行SQL语句后返回的数据分别填充到Excel的相应单元格,实现多级标题的Excel表单自动生成,若标题或表单数据加工逻辑发生变化,仅需要配置表单模板即可,降低了Excel表单开发的难度。
技术领域
本发明涉及计算机技术领域,更具体的,涉及一种多级标题的Excel表单生成方法及装置。
背景技术
在业务系统中经常需要制作Excel表单,随着业务系统中数据的类型越来越丰富,为了满足业务需要可能会需要制作多级标题的表单,制作多级标题的表单涉及多行单元格合并、多列单元格合并等,增大了Excel表单的制作难度。
目前一般通过程序生成包括多级标题的复杂Excel表单,将标题列写在程序中,如果标题列发生变化就需要修改代码,表单内容的SQL语句也是写在程序中,如果表单数据加工逻辑发生变化就需要修改代码。非常不灵活,且会带来很大的开发工作量。
发明内容
有鉴于此,本发明提供了一种多级标题的Excel表单生成方法及装置,降低了包括多级标题的复杂Excel表单的开发难度。
为了实现上述发明目的,本发明提供的具体技术方案如下:
一种多级标题的Excel表单生成方法,包括:
在接收到表单生成指令的情况下,解析所述表单生成指令,得到预先配置的表单模板和用户输入的动态参数值;
解析所述表单模板,得到表单的多级标题中每个标题在Excel中的位置以及表单列与SQL语句中字段的映射关系;
根据所述表单的多级标题中每个标题在Excel中的位置,绘制所述表单的多级标题;
将所述动态参数值代入所述SQL语句,并执行所述SQL语句,每个所述动态参数值分别对应所述SQL语句中的一个字段;
依据所述表单列与所述SQL语句中字段的映射关系,将执行所述SQL语句后返回的数据分别填充到Excel的相应单元格。
可选的,解析所述表单模板,得到表单的多级标题中每个标题在Excel中的位置以及表单列与SQL语句中字段的映射关系,包括:
调用递归算法解析所述表单模板中的多级标题表达式,得到所述表单的多级标题中每个标题对应的位置数组,位置数组表示标题在Excel中的位置,位置数组中的元素包括:标题名、开始行号、开始列号、结束行号、结束列号和特殊处理标志;
解析所述表单模板中所述表单列与所述SQL语句中字段的映射关系,得到每个所述表单列对应的映射关系数组,映射关系数组中的元素包括:表单列和字段名。
可选的,所述多级标题表达式包括多个标题,标题之间通过间隔符隔开,标题之间通过嵌套标志表示标题之间的层级,所述嵌套标志包括开始嵌套标志和结束嵌套标志。
可选的,所述调用递归算法解析所述表单模板中的多级标题表达式,得到所述表单的多级标题中每个标题对应的位置数组,包括:
定义所述递归算法中的全局列表变量、结构体和全局变量,所述全局列表变量由多个结构体构成,所述结构体中的元素包括:标题名、开始行号、开始列号、结束行号、结束列号和特殊处理标志,所述全局变量表示嵌套深度;
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于中银金融科技有限公司,未经中银金融科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202210874859.X/2.html,转载请声明来源钻瓜专利网。
- 上一篇:一种管道清淤机器人
- 下一篇:一种水下机器人360°全景影像应用系统