Java 實現 pdf 和 Excel 的生成及數據動態插入、導出

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. 接下來就需要詳細的配置你的數據源了

數據源即:你代碼中實體類中對應的數據(注意字段一定要一一對應),配置完畢就可以保存進行下面的代碼編寫工作了。

代碼的編寫

假定我們實體類什麼的都已經編寫完成、數據通過前端傳入獲取、模板位置在 E 盤根目錄下名字爲:車輛維修審批單. pdf

導入 jar 包:

`

實現生成 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 data = **new** HashMap();               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;

/**
 * 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 list = **new** ArrayList();     **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>  */</list **private** List<list> head() {     List<list> list = **new** ArrayList<list>();     List head0 = **new** ArrayList();     head0.add("序號");     List head1 = **new** ArrayList();     head1.add("姓名");     List head2 = **new** ArrayList();     head2.add("證件號碼");     List head3 = **new** ArrayList();     head3.add("聯繫電話");     List head4 = **new** ArrayList();     head4.add("工作所在單位");     List head5 = **new** ArrayList();     head5.add("是否接觸疑似病例");     List head6 = **new** ArrayList();     head6.add("是否與隔離人員同住");     List head7 = **new** ArrayList();     head7.add("當前狀態");     List head8 = **new** ArrayList();     head8.add("當前健康狀態");     List head9 = **new** ArrayList();     head9.add("體溫(°C)");     List head10 = **new** ArrayList();     head10.add("當前所在地址");     List head11 = **new** ArrayList();     head11.add("當前居住地址");     List head12 = **new** ArrayList();     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; } </list</list</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;     } }

d. 測試

已經全部完成 PDF 和 Excel 的生成、插入、導出功能。

本文由 Readfog 進行 AMP 轉碼,版權歸原作者所有。
來源https://mp.weixin.qq.com/s/NApAuninphArpT2X3DnxbA