[发明专利]一种实现二级联动的文件转换方法及系统在审
申请号: | 202210269129.7 | 申请日: | 2022-03-18 |
公开(公告)号: | CN114757148A | 公开(公告)日: | 2022-07-15 |
发明(设计)人: | 訾仁凯;李凡平;王堃 | 申请(专利权)人: | 以萨技术股份有限公司 |
主分类号: | G06F40/151 | 分类号: | G06F40/151 |
代理公司: | 济南圣达知识产权代理有限公司 37221 | 代理人: | 杨琪 |
地址: | 266427 山东省青岛*** | 国省代码: | 山东;37 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 实现 二级 联动 文件 转换 方法 系统 | ||
本发明提供了一种实现二级联动的文件转换方法及系统,包括:提取获取的文件的除二级联动下拉框的表头外的所有表头数据,并新建一个主工作簿;提取获取的文件的除二级联动下拉框的表头外的所有下拉框类型的表头数据及其选项值、以及二级联动下拉框中的一级下拉框和二级下拉框的表头数据以及选项值,将二级下拉框的表头数据作为一级下拉框的选项值;基于每个下拉框类型的表头数据,新建一个下拉框工作簿,并将每个下拉框类型的表头数据对应的选项值,作为对应下拉框工作簿中的内容,同时将下拉框工作簿中的内容提取出来作为主工作簿中对应表头数据的下拉框中选项数据。实现了表头信息的动态呈现。
技术领域
本发明属于文件转换技术领域,尤其涉及一种实现二级联动的文件转换方法及系统。
背景技术
本部分的陈述仅仅是提供了与本发明相关的背景技术信息,不必然构成在先技术。
目前由于基于微软的OpenXML标准和PHP语言的PhpExcel类库已经停止更新,所以多数新开发的项目都开始使用PhpSpreadsheet类库来读取、写入不同格式的Office Excel文档,当前大多数的导入导出功能的字段范围都是提前固定好的,用户在进行导入时只能在固定的字段下填写内容,导出时也只能导出固定字段下的数据,在设置二级联动下拉框时大多是使用INDIRECT函数来实现。
当前大多数的导入导出功能的字段范围都是提前固定好的,形式僵硬,不适用于用户可以自己增加扩展字段的项目;在设置二级联动下拉框时大多是使用INDIRECT函数来实现,但这样的二级联动下拉框如果第二级的单元格内的数据是以数字开头的话会导致在选择完一级下拉框后再选择二级下拉框时无法显示第二级的下拉框的数据。
发明内容
为了解决上述背景技术中存在的技术问题,本发明提供一种实现二级联动的文件转换方法及系统,实现了表头信息的动态呈现。
为了实现上述目的,本发明采用如下技术方案:
本发明的第一个方面提供一种实现二级联动的文件转换方法,其包括:
获取待导出文件或字段表文件;
提取获取的文件的除二级联动下拉框的表头外的所有表头数据,并新建一个主工作簿;
提取获取的文件的除二级联动下拉框的表头外的所有下拉框类型的表头数据及其选项值、以及二级联动下拉框中的一级下拉框和二级下拉框的表头数据以及选项值,将二级下拉框的表头数据作为一级下拉框的选项值;
基于每个下拉框类型的表头数据,新建一个下拉框工作簿,并将每个下拉框类型的表头数据对应的选项值,作为对应下拉框工作簿中的内容,同时将下拉框工作簿中的内容提取出来作为主工作簿中对应表头数据的下拉框中选项数据。
进一步地,若获取的文件为待导出文件,还需要获取待导出文件中需要导出的数据,将数据添加到主工作簿中的单元格中。
进一步地,还包括:获取待导入文件的地址信息,对地址信息进行处理获取上传的文件名,并判断文件类型是否正确,若文件类型正确,获取待导入文件内数据的列数,若列数与主工作簿中表头的个数相等,则提取待导入表格内每一行的数据,将每一行的数据进行样式转换后,插入数据库。
进一步地,所述除二级联动下拉框的表头外的所有表头数据的提取步骤为:
从所述获取的文件中获取除不需要显示的和二级联动下拉框的字段外的所有字段的属性信息,并进行拼接,得到每个字段的表头数据,从而获得除二级联动下拉框的字段外的表头数据文字数组;
确定所述表头数据文字数组中每一个字段的表头数据所对应的字母数组,并去除二级联动下拉框字段所对应的字母;
将字母数组中的值变为所述表头数据文字数组的键名后,表头数据文字数组中的每一个元素为一个主工作簿的表头数据。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于以萨技术股份有限公司,未经以萨技术股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202210269129.7/2.html,转载请声明来源钻瓜专利网。