反馈已提交

网络繁忙

Excel直接转成模板cpt

  • 文档创建者:lu123
  • 历史版本:21
  • 最近更新:帆软应用复用-Cat 于 2023-03-15
  • 1. 概述

    1.1 应用场景

    存在很多 Excel 文件,要将它们转成 cpt 模板,不想通过设计器手动一张张导入,希望用程序在后台批量转换。

    1.2 实现原理

    通过程序读取 Excel 文件转为模板 TemplateWorkBook,然后把模板输出为 cpt 文件。

    1)读取 Excel 文件转为模板TemplateWorkBook

    File excelFile = new File("D:\\aa.xlsx"); // 获取EXCEL文件
    FileInputStream a = new FileInputStream(excelFile);

    2)输出成 cpt 文件

    2003 版 Excel:

    TemplateWorkBook tpl = new ExcelReportImporter().generateWorkBookByStream(a);
    OutputStream outputStream = new FileOutputStream(new File("D:\\abc.cpt")); // 转换成cpt模板
    ((WorkBook) tpl).export(outputStream);

    2007 版 Excel:

    TemplateWorkBook tpl = new Excel2007ReportImporter().generateWorkBookByStream(a);
    OutputStream outputStream = new FileOutputStream(new File("D:\\abc.cpt")); // 转换成cpt模板
    ((WorkBook) tpl).export(outputStream);

    2. 示例

    下面实现读取一个Excel 文件后将其转换为 cpt 模板。准备一个Excel 文件 aa.xlsx。如下图所示:

    222

    点击可下载:aa.xlsx

    2.1 准备编译环境

    编译程序前,需先创建一个 Java 工程环境,并且需要一个 Java 编辑器,如 Eclipse 或 idea 。

    在编辑器工程中引入 FineReport 工程 JAR 包。包括安装的报表工程

    • %FR_HOME%\webapps\webroot\WEB-INF\lib目录下 fine 开头的 12 个 JAR 包。

    • %FR_HOME%\webapps\webroot\WEB-INF\lib目录下的 sqlite-jdbc.jar

    • %Tomcat_HOME%\libTomcat目录下的 servlet-api.jar

    • %JAVA_HOME%\jdk\lib JDK 目录下的 tools.jar

    • slf4j-simple-1.7.25.jar ,点击可下载:slf4j-simple-1.7.25.rar

    详细引入过程可参考:编译Java程序 

    2.2 编写 Java 程序

    在编辑器中编写 Java 程序 ExcelToCpt.java,即引入必要类后,读取 Excel 文件后转为 cpt 模板。完整代码可参见:

    注1:用户使用时,注意将示例代码中的工程路径、Excel 存放路径、模板名称和导出路径替换为用户自己环境下的。

    注2:这里以 xlsx 代码为例,xls 代码按照 1.2节进行修改,并修改 import 包即可。

    https://code.fanruan.com/demo/example/src/release/10.0/src/main/java/com/fr/io/ExcelToCpt.java

    2.3 编译 Java 文件

    Java 程序编写完成后,在编译器中编译 ExcelToCpt.java ,编译通过后,就会在代码中导出路径的文件夹生成就会在对应路径下导出 abc.cpt 模板文件。用设计器打开模板后就可以看到,Excel 里面的数据已经保存至模板文件里面了。如下图所示:

    222

    附件列表


    主题: 二次开发
    已经是第一篇
    已经是最后一篇
    • 有帮助
    • 没帮助
    • 只是浏览
    中文(简体)

    鼠标选中内容,快速反馈问题

    鼠标选中存在疑惑的内容,即可快速反馈问题,我们将会跟进处理。

    不再提示

    10s后关闭



    AI

    联系我们
    在线支持
    获取专业技术支持,快速帮助您解决问题
    工作日9:00-12:00,13:30-17:30在线
    页面反馈
    针对当前网页的建议、问题反馈
    售前咨询
    采购需求/获取报价/预约演示
    或拨打: 400-811-8890 转1
    qr
    热线电话
    咨询/故障救援热线:400-811-8890转2
    总裁办24H投诉:17312781526
    提交页面反馈
    仅适用于当前网页的意见收集,帆软产品问题请在 问答板块提问前往服务平台 获取技术支持