JAVA實現(xiàn)PDF和EXCEL生成和數(shù)據(jù)動態(tài)插入以及導(dǎo)出

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

1功戚、第一步:PDF 制作模板

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

a.Word 里面制作模板

圖片

b. 更改名字為 .pdf 形式

image.gif

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

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

圖片

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

圖片

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

image.gif

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

2、代碼的編寫(假定我們實體類什么的都已經(jīng)編寫完成妙真、數(shù)據(jù)通過前端傳入獲取缴允、模板位置在 E 盤根目錄下名字為:車輛維修審批單. pdf)
導(dǎo)入 jar 包:
<!-- PDF導(dǎo)出-->
<!-- https://mvnrepository.com/artifact/com.itextpdf/itextpdf -->
<dependency>
    <groupId>com.itextpdf</groupId>
    <artifactId>itextpdf</artifactId>
    <version>5.5.13</version>
</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 file;
            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<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導(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) Excel 生成和數(shù)據(jù)插入踢俄、導(dǎo)出

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

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

1. 表頭對應(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<ExportYqfkdj> list = new ArrayList<ExportYqfkdj>();
        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<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("聯(lián)系電話");
        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("當(dāng)前狀態(tài)");
        List<String> head8 = new ArrayList<String>();
        head8.add("當(dāng)前健康狀態(tài)");
        List<String> head9 = new ArrayList<String>();
        head9.add("體溫(°C)");
        List<String> head10 = new ArrayList<String>();
        head10.add("當(dāng)前所在地址");
        List<String> head11 = new ArrayList<String>();
        head11.add("當(dāng)前居住地址");
        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 = "疫情防控查詢導(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;file)));
            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. 測試
圖片

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

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末琳钉,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子蛛倦,更是在濱河造成了極大的恐慌歌懒,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,734評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件溯壶,死亡現(xiàn)場離奇詭異及皂,居然都是意外死亡,警方通過查閱死者的電腦和手機且改,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,931評論 3 394
  • 文/潘曉璐 我一進(jìn)店門验烧,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人又跛,你說我怎么就攤上這事碍拆。” “怎么了慨蓝?”我有些...
    開封第一講書人閱讀 164,133評論 0 354
  • 文/不壞的土叔 我叫張陵感混,是天一觀的道長。 經(jīng)常有香客問我礼烈,道長弧满,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,532評論 1 293
  • 正文 為了忘掉前任此熬,我火速辦了婚禮谱秽,結(jié)果婚禮上洽蛀,老公的妹妹穿的比我還像新娘。我一直安慰自己疟赊,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,585評論 6 392
  • 文/花漫 我一把揭開白布峡碉。 她就那樣靜靜地躺著近哟,像睡著了一般。 火紅的嫁衣襯著肌膚如雪鲫寄。 梳的紋絲不亂的頭發(fā)上吉执,一...
    開封第一講書人閱讀 51,462評論 1 302
  • 那天,我揣著相機與錄音地来,去河邊找鬼戳玫。 笑死,一個胖子當(dāng)著我的面吹牛未斑,可吹牛的內(nèi)容都是我干的咕宿。 我是一名探鬼主播,決...
    沈念sama閱讀 40,262評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼蜡秽,長吁一口氣:“原來是場噩夢啊……” “哼府阀!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起芽突,我...
    開封第一講書人閱讀 39,153評論 0 276
  • 序言:老撾萬榮一對情侶失蹤试浙,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后寞蚌,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體田巴,經(jīng)...
    沈念sama閱讀 45,587評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,792評論 3 336
  • 正文 我和宋清朗相戀三年挟秤,在試婚紗的時候發(fā)現(xiàn)自己被綠了壹哺。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,919評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡煞聪,死狀恐怖斗躏,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情昔脯,我是刑警寧澤啄糙,帶...
    沈念sama閱讀 35,635評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站云稚,受9級特大地震影響隧饼,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜静陈,卻給世界環(huán)境...
    茶點故事閱讀 41,237評論 3 329
  • 文/蒙蒙 一燕雁、第九天 我趴在偏房一處隱蔽的房頂上張望诞丽。 院中可真熱鬧,春花似錦拐格、人聲如沸僧免。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,855評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽懂衩。三九已至,卻和暖如春金踪,著一層夾襖步出監(jiān)牢的瞬間浊洞,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,983評論 1 269
  • 我被黑心中介騙來泰國打工胡岔, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留法希,地道東北人。 一個月前我還...
    沈念sama閱讀 48,048評論 3 370
  • 正文 我出身青樓靶瘸,卻偏偏與公主長得像苫亦,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子奕锌,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,864評論 2 354

推薦閱讀更多精彩內(nèi)容