1. 概述
同一张模板,通过 原样导出 至 Excel 中,再刷新模板导入该 Excel 的时候,发现导入错位的问题,如下图所示:
1.2 解决思路
这是因为 FineReport 新增了一个双向导入的功能,即 Excel 双向导入,其处理逻辑发生了变化,并对模板中合并的单元格进行了处理,导致导入错乱的情况出现,那么此时只需要在模板中导出隐藏行列,并使在导入 Excel 的时候,在配置文件中关闭双向导入即可。(双向导入默认关闭的,如果开启了需要关闭)
2. 操作步骤
2.1 模板准备
如上效果图所示,准备如下图所示的模板:
参数面板中 有2 个参数:starttime 和 endtime,其中开始日期的默认值为:DATEDELTA(today(), if(tointeger(WEEKDAY($Date)) == 0, -6, 1 - WEEKDAY($Date))),结束日期的默认值为:DATEDELTA(today(), if(tointeger(WEEKDAY($Date)) == 0, 0, 7 - WEEKDAY($Date)))。
DATEDELTA() 等函数的具体含义请查看 日期常用处理函数。
合并 B3 和 C3 单元格,其值为:=range(date(year($starttime),month($starttime),day($starttime)),date(year($endtime),month($endtime),day($endtime))),合并D3和E3单元格,其值为=WEEKDAY(B3),合并 F3 和 G3 单元格,设置其 控件类型 为 文本控件。
注:模板中要出现合并的单元格。
2.2 导出 Excel
保存模板,点击 填报预览,在web端打开该模板,并输入值班人字段值,如下图,输入完成之后,点击工具栏上的输出>Excel>原样导出,如下图:
此时,就会导出如上图所示的 Excel。
2.3 导入 Excel
回到设计器界面,根据 导入行式报表 中的操作步骤,为该模板的工具栏添加 ,添加完成之后,重新填报预览该模板,点击导入 Excel,选择刚刚导出的 Excel 文件,即可看到如下图所示效果,位置错乱:
2.4 导出隐藏行列
回到设计器,点击
,勾选 和 ,如下图:2.5 结果查看
此时再重新导出 Excel,导入 Excel,就可以看到位置不会发生错乱了。