溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Java怎么實現(xiàn)pdf和Excel的生成及數(shù)據(jù)動態(tài)插入、導(dǎo)出

發(fā)布時間:2021-07-13 14:31:09 來源:億速云 閱讀:130 作者:chen 欄目:web開發(fā)

本篇內(nèi)容介紹了“Java怎么實現(xiàn)pdf和Excel的生成及數(shù)據(jù)動態(tài)插入、導(dǎo)出”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

1 序言

Excel、PDF的導(dǎo)出、導(dǎo)入是我們工作中經(jīng)常遇到的一個問題,剛好今天公司業(yè)務(wù)遇到了這個問題,順便記個筆記以防下次遇到相同的問題而束手無策。

公司有這么兩個需求:

需求一、給了一個表單,讓把查出來的數(shù)據(jù)組裝到表單中并且提供以PDF格式的下載功能。

需求二、將數(shù)據(jù)查出來以Excel表格的形式下載下來。

Java實現(xiàn)PDF的生成和數(shù)據(jù)動態(tài)插入、導(dǎo)出功能

1、第一步:PDF制作模板

因為PDF常用的軟件不讓支持編輯,我們就先使用WPS以Word的形式進(jìn)行編輯制作出與客戶需求一樣的樣式,然后直接另存為 .pdf  的形式如下圖所示:

a.Word里面制作模板

Java怎么實現(xiàn)pdf和Excel的生成及數(shù)據(jù)動態(tài)插入、導(dǎo)出

b.更改名字為 .pdf形式

Java怎么實現(xiàn)pdf和Excel的生成及數(shù)據(jù)動態(tài)插入、導(dǎo)出

c.這時需要用到一個叫:Adobe Acrobat DC的軟件,具體操作如下:

用Adobe Acrobat DC打開我們剛才改過名字的PDF文件,點擊右下角的“更多工具”按鈕

Java怎么實現(xiàn)pdf和Excel的生成及數(shù)據(jù)動態(tài)插入、導(dǎo)出

到下面這個頁面再點擊“準(zhǔn)備表單”按鈕

Java怎么實現(xiàn)pdf和Excel的生成及數(shù)據(jù)動態(tài)插入、導(dǎo)出

d.接下來就需要詳細(xì)的配置你的數(shù)據(jù)源了

Java怎么實現(xiàn)pdf和Excel的生成及數(shù)據(jù)動態(tài)插入、導(dǎo)出

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

2 代碼的編寫

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

導(dǎo)入jar包:

<dependency>     <groupId>com.itextpdfgroupId>     <artifactId>itextpdfartifactId>     <version>5.5.13version> dependency>

實現(xiàn)生成PDF、數(shù)據(jù)插入、導(dǎo)出

@RegisterToSMP(serviceDisplay = "預(yù)覽頁面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 根據(jù)表單生成一個新的pdf         ps = new PdfStamper(reader, os);         // 4 獲取pdf表單         AcroFields form = ps.getAcroFields();         // 5給表單添加中文字體 這里采用系統(tǒng)字體。不設(shè)置的話,中文可能無法顯示         BaseFont bf = BaseFont.createFont("C:/WINDOWS/Fonts/SIMSUN.TTC,1",                       BaseFont.IDENTITY_H, BaseFont.EMBEDDED);         form.addSubstitutionFont(bf);         // 6查詢數(shù)據(jù)================================================         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導(dǎo)出成功***********************");     } catch (Exception e) {          log.error("*******************PDF導(dǎo)出失敗***********************");         e.printStackTrace();     } finally {         try {             ps.close();             reader.close();             os.close();         } catch (Exception e) {             e.printStackTrace();         }     }     return null; }

 3 測試

Java怎么實現(xiàn)pdf和Excel的生成及數(shù)據(jù)動態(tài)插入、導(dǎo)出

Java怎么實現(xiàn)pdf和Excel的生成及數(shù)據(jù)動態(tài)插入、導(dǎo)出

Java實現(xiàn)Excel生成和數(shù)據(jù)插入、導(dǎo)出

這個比較簡單,直接上代碼(假定你的實體類、查詢什么的都已經(jīng)寫好)注意:實體類一個是你自己的數(shù)據(jù)實體類還有一個是你導(dǎo)出時表格中對應(yīng)的實體類。100道Java中高級面試題匯總

我們以一個真實的公司業(yè)務(wù)來舉個例子(一個統(tǒng)計疫情登記人員信息的Excel導(dǎo)出功能)

a.表頭對應(yīng)實體類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;     /**      * 聯(lián)系電話      */     private String lxdh;         /**      * 申請人工作單位      */     private String sqrGzdw;         /**      * 是否接觸過疑似病例      */     private String sfjcgysbl;     /**      * 當(dāng)前是否與居家隔離人員同住      */     private String sfyjjglrytz;         /**      * 當(dāng)前狀態(tài)      */     private String dqzt;     /**      * 當(dāng)前健康狀態(tài)      */     private String dqjkzt;      /**      * 當(dāng)前體溫      */     private String dqtw;     /**      * 當(dāng)前所在地址      */     private String dqszdz;     /**      * 當(dāng)前居住地址      */     private String dqjzdz;     /**      * 提交時間      * */     private String tjsj; }

 b.Service層

/**  * 導(dǎo)出  * @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 {         /* 查詢導(dǎo)出信息 */         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; } /**  * 疫情防控信息導(dǎo)出表頭  * @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("聯(lián)系電話");     List head4 = new ArrayList();     head4.add("工作所在單位");     List head5 = new ArrayList();     head5.add("是否接觸疑似病例");     List head6 = new ArrayList();     head6.add("是否與隔離人員同住");     List head7 = new ArrayList();     head7.add("當(dāng)前狀態(tài)");     List head8 = new ArrayList();     head8.add("當(dāng)前健康狀態(tài)");     List head9 = new ArrayList();     head9.add("體溫(&deg;C)");     List head10 = new ArrayList();     head10.add("當(dāng)前所在地址");     List head11 = new ArrayList();     head11.add("當(dāng)前居住地址");     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 = "疫情防控查詢導(dǎo)出") @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.測試

Java怎么實現(xiàn)pdf和Excel的生成及數(shù)據(jù)動態(tài)插入、導(dǎo)出

已經(jīng)全部完成PDF和Excel的生成、插入、導(dǎo)出功能。

“Java怎么實現(xiàn)pdf和Excel的生成及數(shù)據(jù)動態(tài)插入、導(dǎo)出”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI