EasyPOI 的使用說明

說明

easypoi功能如同名字easy,主打的功能就是容易,讓一個沒見接觸過poi的人員
就可以方便的寫出Excel導(dǎo)出,Excel模板導(dǎo)出,Excel導(dǎo)入,Word模板導(dǎo)出,通過簡單的注解和模板
語言(熟悉的表達式語法),完成以前復(fù)雜的寫法

教程所使用的工具

前端 :

后端 :SpringBoot + easyPOI + MyBatis + MyBatis-Plus + Lombok

數(shù)據(jù)庫 : MySQL

工具 : IDEA + Navicat

GitHub項目地址 : EasyPOI

查看實體類的模型

package com.inet.codebase.entity;

import cn.afterturn.easypoi.excel.annotation.Excel;
import cn.afterturn.easypoi.excel.annotation.ExcelTarget;
import com.baomidou.mybatisplus.annotation.TableName;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import java.time.LocalDateTime;
import java.io.Serializable;
import java.util.Date;

import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.experimental.Accessors;

/**
 * <p>
 * 用戶實體類
 * </p>
 *
 * @author HCY
 * @since 2020-10-13
 */
@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
@TableName("tbl_user")
@ExcelTarget("users")
public class User implements Serializable {

    private static final long serialVersionUID = 1L;

    /**
     * 用戶序號
     */

    @TableId(value = "user_id", type = IdType.AUTO)
    private Integer userId;

    /**
     * 用戶姓名
     */
    @Excel(name = "姓名")
    private String userName;

    /**
     * 用戶生日
     */
    @Excel(name = "生日" , importFormat = "yyyy-MM-dd HH:mm:ss")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
    private Date userBirthday;

    /**
     * 用戶愛好
     */
    @Excel(name = "愛好")
    private String userHabby;

    /**
     * 用戶身份證
     */
    @Excel(name = "身份證")
    private String userIdentity;

    /**
     * 用戶住址
     */
    @Excel(name = "住址")
    private String userAddress;

}

關(guān)于實體類的繼承 Serializable 的問題,移步至

實體類為什么需要繼承序列話Serializable

關(guān)于EasyPOI的注解說明

@Excel 作用到filed上面,是對Excel一列的一個描述

@ExcelCollection表示一個集合,主要針對一對多的導(dǎo)出,比如一個老師對應(yīng)多個科目,科目就可以用集合表示

@ExcelEntity 表示一個繼續(xù)深入導(dǎo)出的實體,但他沒有太多的實際意義,只是告訴系統(tǒng)這個對象里面同樣有導(dǎo)出的字段

@ExcelIgnore 和名字一樣表示這個字段被忽略跳過這個導(dǎo)出

@ExcelTarget 這個是作用于最外層的對象,描述這個對象的id,以便支持一個對象可以針對不同導(dǎo)出做出不同處理

關(guān)于注解的大多數(shù)的參數(shù),還是移步去至

官網(wǎng)

導(dǎo)入的實例

/**
     * 導(dǎo)入Excel
     * @author HCY
     * @since 2020-10-14
     * @throws Exception
     */
    @Test
    void contextLoads1() throws Exception {
        //文件的位置,Excel文件的說明需要和實體類所對應(yīng)
        File file = new File("C:\\Users\\Administrator.DESKTOP-TSJVEJ5\\Desktop\\test\\test.xlsx");
        //導(dǎo)入的標(biāo)題和說明的設(shè)置
        ImportParams params = new ImportParams();
        //設(shè)置標(biāo)題
        params.setTitleRows(1);
        //設(shè)置說明
        params.setHeadRows(1);
        //導(dǎo)入獲取集合
        List<User> users = ExcelImportUtil.importExcel(file, User.class, params);
        //遍歷集合
        users.forEach(System.out :: println);
        //進行批量添加
        boolean batch = userService.saveBatch(users);
        //輸出結(jié)果
        System.out.println(batch);
    }

導(dǎo)入的xlsx文件的實例樣子

導(dǎo)入的excel實例

導(dǎo)出的實例

    /**
     * 導(dǎo)出Excel
     * @author HCY
     * @since 2020-10-14
     */
    @Test
    void contextLoads2() throws Exception {
        //查詢?nèi)?        List<User> list = userService.list();
        //設(shè)置Excel的描述文件
        ExportParams exportParams = new ExportParams("用戶列表的所有數(shù)據(jù)", "用戶信息" , ExcelType.XSSF);
        //進行導(dǎo)出的基本操作
        Workbook workbook = ExcelExportUtil.exportExcel(exportParams, User.class, list);
        //輸入輸出流地址
        FileOutputStream fileOutputStream = new FileOutputStream("C:\\Users\\Administrator.DESKTOP-TSJVEJ5\\Desktop\\test\\users.xlsx");
        //進行輸出流
        workbook.write(fileOutputStream);
        //關(guān)流
        fileOutputStream.close();
        workbook.close();
    }

導(dǎo)出的Excel實例

導(dǎo)出的xlsx文件
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市颗胡,隨后出現(xiàn)的幾起案子毫深,更是在濱河造成了極大的恐慌,老刑警劉巖毒姨,帶你破解...
    沈念sama閱讀 219,539評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件哑蔫,死亡現(xiàn)場離奇詭異,居然都是意外死亡弧呐,警方通過查閱死者的電腦和手機鸳址,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,594評論 3 396
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來泉懦,“玉大人瞄摊,你說我怎么就攤上這事∴头牛” “怎么了戏自?”我有些...
    開封第一講書人閱讀 165,871評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長邓嘹。 經(jīng)常有香客問我酣栈,道長,這世上最難降的妖魔是什么汹押? 我笑而不...
    開封第一講書人閱讀 58,963評論 1 295
  • 正文 為了忘掉前任矿筝,我火速辦了婚禮,結(jié)果婚禮上棚贾,老公的妹妹穿的比我還像新娘窖维。我一直安慰自己榆综,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,984評論 6 393
  • 文/花漫 我一把揭開白布铸史。 她就那樣靜靜地躺著鼻疮,像睡著了一般。 火紅的嫁衣襯著肌膚如雪琳轿。 梳的紋絲不亂的頭發(fā)上判沟,一...
    開封第一講書人閱讀 51,763評論 1 307
  • 那天,我揣著相機與錄音崭篡,去河邊找鬼挪哄。 笑死,一個胖子當(dāng)著我的面吹牛琉闪,可吹牛的內(nèi)容都是我干的中燥。 我是一名探鬼主播,決...
    沈念sama閱讀 40,468評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼塘偎,長吁一口氣:“原來是場噩夢啊……” “哼疗涉!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起吟秩,我...
    開封第一講書人閱讀 39,357評論 0 276
  • 序言:老撾萬榮一對情侶失蹤咱扣,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后涵防,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體闹伪,經(jīng)...
    沈念sama閱讀 45,850評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,002評論 3 338
  • 正文 我和宋清朗相戀三年壮池,在試婚紗的時候發(fā)現(xiàn)自己被綠了偏瓤。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,144評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡椰憋,死狀恐怖厅克,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情橙依,我是刑警寧澤证舟,帶...
    沈念sama閱讀 35,823評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站窗骑,受9級特大地震影響女责,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜创译,卻給世界環(huán)境...
    茶點故事閱讀 41,483評論 3 331
  • 文/蒙蒙 一抵知、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦刷喜、人聲如沸残制。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,026評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至仰禽,卻和暖如春氮墨,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背吐葵。 一陣腳步聲響...
    開封第一講書人閱讀 33,150評論 1 272
  • 我被黑心中介騙來泰國打工规揪, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人温峭。 一個月前我還...
    沈念sama閱讀 48,415評論 3 373
  • 正文 我出身青樓猛铅,卻偏偏與公主長得像,于是被迫代替她去往敵國和親凤藏。 傳聞我的和親對象是個殘疾皇子奸忽,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,092評論 2 355