广告
返回顶部
首页 > 资讯 > 精选 >Java怎么实现pdf和Excel的生成及数据动态插入与导出
  • 221
分享到

Java怎么实现pdf和Excel的生成及数据动态插入与导出

2023-06-27 10:06:02 221人浏览 独家记忆
摘要

这篇文章主要介绍“Java怎么实现pdf和excel的生成及数据动态插入与导出”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Java怎么实现pdf和Excel的生成及数据动态插入与导出”文章能帮助大

这篇文章主要介绍“Java怎么实现pdfexcel的生成及数据动态插入与导出”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Java怎么实现pdf和Excel的生成及数据动态插入与导出”文章能帮助大家解决问题。

一、序言

Excel、PDF的导出、导入是我们工作中经常遇到的一个问题,刚好今天公司业务遇到了这个问题,顺便记个笔记以防下次遇到相同的问题而束手无策。

公司有这么两个需求:

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

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

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

1、第一步:PDF制作模板

因为 PDF 常用的软件不让支持编辑,我们就先使用 WPS 以 Word 的形式进行编辑制作出与客户需求一样的样式,然后直接另存为 .pdf 的形式

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;}

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

这个比较简单,直接上代码(假定你的实体类、查询什么的都已经写好)注意:实体类一个是你自己的数据实体类还有一个是你导出时表格中对应的实体类。100道 Java中高级面试题汇总

我们以一个真实的公司业务来举个例子(一个统计疫情登记人员信息的Excel导出功能)

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

import lombok.Data;@Datapublic 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 层

@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;}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;    }}

关于“Java怎么实现pdf和Excel的生成及数据动态插入与导出”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网精选频道,小编每天都会为大家更新不同的知识点。

--结束END--

本文标题: Java怎么实现pdf和Excel的生成及数据动态插入与导出

本文链接: https://www.lsjlt.com/news/309332.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Java怎么实现pdf和Excel的生成及数据动态插入与导出
    这篇文章主要介绍“Java怎么实现pdf和Excel的生成及数据动态插入与导出”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Java怎么实现pdf和Excel的生成及数据动态插入与导出”文章能帮助大...
    99+
    2023-06-27
  • Java怎么实现pdf和Excel的生成及数据动态插入、导出
    本篇内容介绍了“Java怎么实现pdf和Excel的生成及数据动态插入、导出”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读...
    99+
    2022-10-19
  • 怎么用Java Hutool工具实现验证码生成及Excel文件的导入和导出
    这篇文章主要介绍“怎么用Java Hutool工具实现验证码生成及Excel文件的导入和导出”,在日常操作中,相信很多人在怎么用Java Hutool工具实现验证码生成及Excel文件的导入和导出问题上存在疑惑,小编查阅...
    99+
    2023-06-21
  • Java中怎么操作Jxl实现导出数据生成Excel表格数据文件
    这篇文章主要讲解了“Java中怎么操作Jxl实现导出数据生成Excel表格数据文件”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java中怎么操作Jxl实现...
    99+
    2022-10-19
  • MySQL数据备份、还原、数据库迁移及表的导出和导入怎么实现
    本篇内容介绍了“MySQL数据备份、还原、数据库迁移及表的导出和导入怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读...
    99+
    2022-11-30
    mysql
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作