1. 程式人生 > >Java實現PDF和Excel生成和資料動態插入以及匯出

Java實現PDF和Excel生成和資料動態插入以及匯出

一、序言

Excel、PDF的匯出、匯入是我們工作中經常遇到的一個問題,剛好今天公司業務遇到了這個問題,順便記個筆記以防下次遇到相同的問題而束手無策。

公司有這麼兩個需求:

需求一、給了一個表單,讓把查出來的資料組裝到表單中並且提供以PDF格式的下載功能。

需求二、將資料查出來以Excel表格的形式下載下來。

二、Java實現PDF的生成和資料動態插入、匯出功能

1、第一步:PDF製作模板

因為PDF常用的軟體不讓支援編輯,我們就先使用WPS以Word的形式進行編輯製作出與客戶需求一樣的樣式,然後直接另存為 .pdf 的形式如下圖所示:

a.Word裡面製作模板

 b.更改名字為 .pdf形式

c.這時需要用到一個叫:Adobe Acrobat DC的軟體(可以白嫖7天^_^),具體操作如下:

用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生成和資料插入、匯出

這個比較簡單,直接上程式碼(假定你的實體類、查詢什麼的都已經寫好)注意:實體類一個是你自己的資料實體類還有一個是你匯出時表格中對應的實體類

我們以一個真實的公司業務來舉個例子(一個統計疫情登記人員資訊的Excel匯出功能)

1.表頭對應實體類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;
        }
    }
d.測試

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

參考連結:https://www.cnblogs.com/wangpeng00700/p/8418594.h