乐趣区

关于java:接了个变态需求生成-Excel-PDF-导出用-Java-怎么实现

作者:慢时光 \
起源:cnblogs.com/Tom-shushu/p/14279357.html

一、序言

Excel、PDF 的导出、导入是咱们工作中常常遇到的一个问题,刚好明天公司业务遇到了这个问题,顺便记个笔记以防下次遇到雷同的问题而大刀阔斧。

公司有这么两个需要:

需要一 、给了一个表单,让把查出来的数据组装到表单中并且提供以 PDF 格局的下载性能。

需要二、 将数据查出来以 Excel 表格的模式下载下来。

二、Java 实现 PDF 的生成和数据动静插入、导出性能

1、第一步:PDF 制作模板

因为 PDF 罕用的软件不让反对编辑,咱们就先应用 WPS 以 Word 的模式进行编辑制作出与客户需要一样的款式,而后间接另存为 .pdf 的模式如下图所示:

a.Word 外面制作模板

b. 更改名字为 .pdf 模式

c. 这时须要用到一个叫:Adobe Acrobat DC 的软件,具体操作如下:

用 Adobe Acrobat DC 关上咱们方才改过名字的 PDF 文件,点击右下角的“更多工具”按钮

到上面这个页面再点击“筹备表单”按钮

d. 接下来就须要具体的配置你的数据源了

数据源即:你代码中实体类中对应的数据(留神字段肯定要一一对应),配置结束就能够保留进行上面的代码编写工作了。

2、代码的编写

假设咱们实体类什么的都曾经编写实现、数据通过前端传入获取、模板地位在 E 盘根目录下名字为:车辆培修审批单.pdf

导入 jar 包:

<!-- PDF 导出 -->
<!-- https://mvnrepository.com/artifact/com.itextpdf/itextpdf -->
<dependency>
    <groupId>com.itextpdf</groupId>
    <artifactId>itextpdf</artifactId>
    <version>5.5.13</version>
</dependency>

实现生成 PDF、数据插入、导出

@RegisterToSMP(serviceDisplay = "预览页面 PDF 下载")
@RequestMapping(value = "/DM/gwclwxsq/qygl/exportPDF$m=query.service",method =RequestMethod.POST)
public String exportPdf(@RequestBody GwclwxsqBean gwclwxsqBean , HttpServletResponse response) throws UnsupportedEncodingException {
    // 1. 指定解析器
    System.setProperty("javax.xml.parsers.DocumentBuilderFactory",
            "com.sun.org.apache.xerces.internal.jaxp.DocumentBuilderFactoryImpl");
    String filename="车辆培修审批单.pdf";
    String path="e:/";
    response.setContentType("application/pdf");
    response.setHeader("Content-Disposition", "attachment;fileName="
            + URLEncoder.encode(filename, "UTF-8"));
    OutputStream os = null;
    PdfStamper ps = null;
    PdfReader reader = null;
    try {os = response.getOutputStream();
        // 2 读入 pdf 表单
        reader = new PdfReader(path+ "/"+filename);
        // 3 依据表单生成一个新的 pdf
        ps = new PdfStamper(reader, os);
        // 4 获取 pdf 表单
        AcroFields form = ps.getAcroFields();
        // 5 给表单增加中文字体 这里采纳零碎字体。不设置的话,中文可能无奈显示
        BaseFont bf = BaseFont.createFont("C:/WINDOWS/Fonts/SIMSUN.TTC,1",
                      BaseFont.IDENTITY_H, BaseFont.EMBEDDED);
        form.addSubstitutionFont(bf);
        // 6 查问数据 ================================================
        Map<String, String> data = new HashMap<String, String>();
              data.put("commitTime", gwclwxsqBean.getCommitTime());
              data.put("driver", gwclwxsqBean.getDriver());
              data.put("carId", gwclwxsqBean.getCarId());
              data.put("carType", gwclwxsqBean.getCarType());
              data.put("repairAddress", gwclwxsqBean.getRepairAddress());
              data.put("repairCost",gwclwxsqBean.getRepairCost());
              data.put("project", gwclwxsqBean.getProject());
              data.put("fwbzzxfzrYj", gwclwxsqBean.getFwbzzxfzrYj());
              data.put("fgldspYj", gwclwxsqBean.getFgldspYj());
              data.put("remarks", gwclwxsqBean.getRemarks());
         // 7 遍历 data 给 pdf 表单表格赋值
        for (String key : data.keySet()) {form.setField(key,data.get(key).toString());
        }
        ps.setFormFlattening(true);
        log.info("*******************PDF 导出胜利 ***********************");
    } catch (Exception e) {log.error("*******************PDF 导出失败 ***********************");
        e.printStackTrace();} finally {
        try {ps.close();
            reader.close();
            os.close();} catch (Exception e) {e.printStackTrace();
        }
    }
    return null;
}

3、测试

三、Java 实现 Excel 生成和数据插入、导出

这个比较简单,间接上代码(假设你的实体类、查问什么的都曾经写好)留神:实体类一个是你本人的数据实体类还有一个是你导出时表格中对应的实体类。100 道 Java 中高级面试题汇总

咱们以一个实在的公司业务来举个例子(一个统计疫情注销人员信息的 Excel 导出性能)

a. 表头对应实体类 ExportYqfkdj.java

import lombok.Data;

/**
 * description:
 * @author: zhouhong
 * @version: V1.0.0
 * @date: 2021 年 1 月 14 日 下午 3:05:54
 */
@Data
public class ExportYqfkdj {
    /**
     * 序号
     */
    private Integer xuhao;
    /**
     * 姓名
     */
    private String xingming;
    /**
     * 证件号码
     */
    private String zjhm;
    /**
     * 联系电话
     */
    private String lxdh;
    /**
     * 申请人工作单位
     */
    private String sqrGzdw;
    /**
     * 是否接触过疑似病例
     */
    private String sfjcgysbl;
    /**
     * 以后是否与居家隔离人员同住
     */
    private String sfyjjglrytz;
    /**
     * 以后状态
     */
    private String dqzt;
    /**
     * 以后衰弱状态
     */
    private String dqjkzt;

    /**
     * 以后体温
     */
    private String dqtw;
    /**
     * 以后所在地址
     */
    private String dqszdz;
    /**
     * 以后寓居地址
     */
    private String dqjzdz;
    /**
     * 提交工夫
     * */
    private String tjsj;
}

b.Service 层

/**
 * 导出
 * @param yqfkdjBean
 * @author zhouhong
 * @return
 * @throws Exception
 */
@Transactional(rollbackFor = { Exception.class})
public DataResult exporYqfkdj(YqfkdjBean yqfkdjBean) throws Exception {DataResult result = new DataResult();
    List<ExportYqfkdj> list = new ArrayList<ExportYqfkdj>();
    try {
        /* 查问导出信息 */
        result = getYqfkMhCXQuery(yqfkdjBean);
        SimpleDateFormat df = new SimpleDateFormat("yyyyMMddhhmmssSSS");
        for (int i = 0; i < result.getTotalcount(); i++) {ExportYqfkdj dmKhfwdcDtjlZxDto = new ExportYqfkdj();
            dmKhfwdcDtjlZxDto = ObjectUtil.parsePojo(result.getResults().get(i), ExportYqfkdj.class);
            dmKhfwdcDtjlZxDto.setXuhao(i + 1);
            list.add(dmKhfwdcDtjlZxDto);
        }
        String filepath = "D:/ 疫情防控信息" + df.format(new Date()) + ".xlsx";
        if (System.getProperty(YqfkdjUtils.Wjdz.NAME).toLowerCase().startsWith(YqfkdjUtils.Wjdz.LI)
                || System.getProperty(YqfkdjUtils.Wjdz.NAME).toLowerCase().startsWith(YqfkdjUtils.Wjdz.LIN)) {filepath = "/home/Tomcat/temp/" + df.format(new Date()) + ".xlsx";
        }
        EasyExcel.write(filepath, ExportYqfkdj.class).head(head()).sheet().doWrite(list);
        result.setResults(list);
        result.setSuccess(true);
        result.setMsg(filepath);
    } catch (Exception e) {result.setSuccess(false);
        result.setMsg(YqfkdjUtils.Cytx.DCSB);
        e.printStackTrace();
        throw e;
    }
    return result;
}
/**
 * 疫情防控信息导出表头
 * @author zhouhong
 * @return List<List<String>>
 */
private List<List<String>> head() {List<List<String>> list = new ArrayList<List<String>>();
    List<String> head0 = new ArrayList<String>();
    head0.add("序号");
    List<String> head1 = new ArrayList<String>();
    head1.add("姓名");
    List<String> head2 = new ArrayList<String>();
    head2.add("证件号码");
    List<String> head3 = new ArrayList<String>();
    head3.add("联系电话");
    List<String> head4 = new ArrayList<String>();
    head4.add("工作所在单位");
    List<String> head5 = new ArrayList<String>();
    head5.add("是否接触疑似病例");
    List<String> head6 = new ArrayList<String>();
    head6.add("是否与隔离人员同住");
    List<String> head7 = new ArrayList<String>();
    head7.add("以后状态");
    List<String> head8 = new ArrayList<String>();
    head8.add("以后衰弱状态");
    List<String> head9 = new ArrayList<String>();
    head9.add("体温 (°C)");
    List<String> head10 = new ArrayList<String>();
    head10.add("以后所在地址");
    List<String> head11 = new ArrayList<String>();
    head11.add("以后寓居地址");
    List<String> head12 = new ArrayList<String>();
    head12.add("提交工夫");
    list.add(head0);
    list.add(head1);
    list.add(head2);
    list.add(head3);
    list.add(head4);
    list.add(head5);
    list.add(head6);
    list.add(head7);
    list.add(head8);
    list.add(head9);
    list.add(head10);
    list.add(head11);
    list.add(head12);
    return list;
}

c.Controller 层

@RegisterToSMP(serviceDisplay = "疫情防控查问导出")
@RequestMapping(value = "/DM/yqfkdj/gr/yqfkdjdc$m=export.service", method = RequestMethod.POST)
public void exportKhfxxx(@RequestBody YqfkdjBean yqfkdjBean, HttpServletResponse resp) throws Exception {DataResult result = new DataResult();
    try {SimpleDateFormat df = new SimpleDateFormat("yyyyMMddhhmmssSSS");
        result = yqfkdjService.exporYqfkdj(yqfkdjBean);
        String filepath = result.getMsg().replace("\"", "");
        File file = new File(filepath);
        String filename = "疫情防控信息" + df.format(new Date()) + ".xlsx";
        InputStream fis = new BufferedInputStream(new FileInputStream(filepath));
        byte[] buffer = new byte[fis.available()];
        fis.read(buffer);
        fis.close();
        resp.reset();
        resp.setHeader("Content-Disposition",
                "attachment;filename=" + new String(filename.replaceAll("","").getBytes("gbk")));
        resp.setHeader("Content-Length", "" + file.length());
        OutputStream os = new BufferedOutputStream(resp.getOutputStream());
        resp.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
        // 输入文件
        os.write(buffer);
        os.flush();
        os.close();} catch (Exception e) {e.printStackTrace();
        log.info(YqfkdjUtils.Cytx.DCSB);
        throw e;
    }
}

测试

曾经全副实现 PDF 和 Excel 的生成、插入、导出性能。

参考链接:https://www.cnblogs.com/wangp…

近期热文举荐:

1.1,000+ 道 Java 面试题及答案整顿 (2021 最新版)

2. 别在再满屏的 if/ else 了,试试策略模式,真香!!

3. 卧槽!Java 中的 xx ≠ null 是什么新语法?

4.Spring Boot 2.6 正式公布,一大波新个性。。

5.《Java 开发手册(嵩山版)》最新公布,速速下载!

感觉不错,别忘了顺手点赞 + 转发哦!

退出移动版