基于Sring Boot和Apache POI的Excel導(dǎo)出實(shí)現(xiàn)示例(完美解決deprecated警告)俯艰。

本文不建議閱讀捡遍。作者已有更好的解決方案:戳這里


前言

最近做公司項(xiàng)目,用到了POI實(shí)現(xiàn)Excel導(dǎo)入導(dǎo)出的功能竹握。
整個(gè)功能做下來(lái)画株,發(fā)現(xiàn)很多大牛的文章都已經(jīng)過(guò)時(shí),會(huì)報(bào)類似The method setBorderBottom(short) from the type HSSFCellStyle is deprecated的警告涩搓,直接使用@SupressWarnings忽略警告顯然是不負(fù)責(zé)任的。因此我直接去翻了Apache POI的官方文檔劈猪,使用了目前官方推薦的新實(shí)現(xiàn)方法昧甘。
順便發(fā)出來(lái),方便沒(méi)有翻閱英文官方文檔習(xí)慣的大家战得。
過(guò)兩天發(fā)實(shí)現(xiàn)導(dǎo)入Excel的示例文章充边。

項(xiàng)目結(jié)構(gòu)簡(jiǎn)介

  • Student.java:學(xué)生實(shí)體。
  • StudentService.java:業(yè)務(wù)類常侦。
  • StudentController.java: web層浇冰。
    (具體每一步的介紹在代碼中都有詳細(xì)的解釋,此處不再贅述聋亡。如果疑惑的地方歡迎留言討論肘习。)

Excel導(dǎo)出代碼展示

Student.java

@Entity
@NoArgsConstructor
@Getter
@Setter
public class Student implements Serializable{

    /** 
     * @fields serialVersionUID 
     */ 
    
    private static final long serialVersionUID = 1L;
    @Id
    @GeneratedValue(generator = "idGenerator")
    @GenericGenerator(name = "idGenerator", strategy = "uuid")
    private String id;
    private String sName;
}

StudentService.java(僅貼出實(shí)現(xiàn)導(dǎo)出功能的方法)

public void exportExcel(String[] ids, OutputStream out) {
        // 根據(jù)傳入的id將要導(dǎo)出的Student對(duì)象放入集合中
        List<Student> list = new ArrayList<>();
        for (int i = 0; i < ids.length; i++) {
            Student student = repository.findOne(ids[i]);
            
            list.add(student);
        }

        // 設(shè)置excel表頭數(shù)據(jù)
        String[] headers = { "學(xué)生ID", "學(xué)生姓名"};
        // 創(chuàng)建excel工作薄
        HSSFWorkbook workbook = new HSSFWorkbook();
        // 創(chuàng)建sheet
        HSSFSheet sheet = workbook.createSheet("數(shù)據(jù)導(dǎo)出");
        // 設(shè)置默認(rèn)列寬為15
        sheet.setDefaultColumnWidth(15);
        // 合并標(biāo)題欄單元格
        sheet.addMergedRegion(new CellRangeAddress(0, 0, 0, headers.length - 1));
        // 定義標(biāo)題欄樣式
        HSSFCellStyle style = workbook.createCellStyle();
        style.setFillForegroundColor(HSSFColorPredefined.SKY_BLUE.getIndex());
        style.setFillPattern(FillPatternType.SOLID_FOREGROUND);
        style.setBorderBottom(BorderStyle.THIN);
        style.setBorderLeft(BorderStyle.THIN);
        style.setBorderRight(BorderStyle.THIN);
        style.setBorderTop(BorderStyle.THIN);
        style.setAlignment(HorizontalAlignment.CENTER);
        style.setVerticalAlignment(VerticalAlignment.CENTER);
        HSSFFont font = workbook.createFont(); 
        font.setColor(HSSFColorPredefined.VIOLET.getIndex());
        font.setFontHeightInPoints((short) 18);
        style.setFont(font);
        // 定義表頭樣式
        HSSFCellStyle style2 = workbook.createCellStyle();
        style2.setFillForegroundColor(HSSFColorPredefined.GREEN.getIndex());
        style2.setFillPattern(FillPatternType.SOLID_FOREGROUND);
        style2.setBorderBottom(BorderStyle.THIN);
        style2.setBorderLeft(BorderStyle.THIN);
        style2.setBorderRight(BorderStyle.THIN);
        style2.setBorderTop(BorderStyle.THIN);
        style2.setAlignment(HorizontalAlignment.CENTER);
        style2.setVerticalAlignment(VerticalAlignment.CENTER);
        HSSFFont font2 = workbook.createFont();
        font2.setFontHeightInPoints((short) 12);
        style2.setFont(font2);
        // 定義數(shù)據(jù)行樣式
        HSSFCellStyle style3 = workbook.createCellStyle();
        style3.setFillForegroundColor(HSSFColorPredefined.LIGHT_YELLOW.getIndex());
        style3.setFillPattern(FillPatternType.SOLID_FOREGROUND);
        style3.setBorderBottom(BorderStyle.THIN);
        style3.setBorderLeft(BorderStyle.THIN);
        style3.setBorderRight(BorderStyle.THIN);
        style3.setBorderTop(BorderStyle.THIN);
        style3.setAlignment(HorizontalAlignment.CENTER);
        style3.setVerticalAlignment(VerticalAlignment.CENTER);
        // 創(chuàng)建行、單元格對(duì)象
        HSSFRow row = null;
        HSSFCell cell = null;
        // 寫(xiě)入標(biāo)題行
        row = sheet.createRow(0);
        row.setHeightInPoints(25);
        cell = row.createCell(0);
        cell.setCellStyle(style);

        HSSFRichTextString textTitle = new HSSFRichTextString("數(shù)據(jù)導(dǎo)出");
        cell.setCellValue(textTitle);
        // 寫(xiě)入表頭
        row = sheet.createRow(1);
        row.setHeightInPoints(17);
        for (int i = 0; i < headers.length; i++) {
            cell = row.createCell(i);
            cell.setCellStyle(style2);
            HSSFRichTextString text = new HSSFRichTextString(headers[i]);
            cell.setCellValue(text);
        }

        // 寫(xiě)入數(shù)據(jù)行
        Iterator<Student> it = list.iterator();
        int index = 2;
        while (it.hasNext()) {
            row = sheet.createRow(index++);
            Student student = (Student) it.next();
            cell = row.createCell(0);
            cell.setCellStyle(style3);
            cell.setCellValue(student.getId());
            cell = row.createCell(1);
            cell.setCellStyle(style3);
            cell.setCellValue(student.getSName());
            
        }
        // 獲取輸出流寫(xiě)文件坡倔。
        try {
            workbook.write(out);    
            out.flush();
            workbook.close();
            out.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
        
    }

StudentController.java(僅貼出實(shí)現(xiàn)導(dǎo)出功能的方法)

    @RequestMapping(value = "/student/export" , method = RequestMethod.GET)
    public void exporMemberFormExcel(@RequestParam(value = "ids", defaultValue = "", required = false) String[] ids, HttpServletResponse res) throws IOException {
        logger.info("---------------導(dǎo)出列表到Excel--------------------");
        res.setContentType("application/msexcel;charset=UTF-8");
        res.addHeader("Content-Disposition", "attachment;filename=members.xls");
        OutputStream out = res.getOutputStream();
        studentService.exportExcel(ids, out);       
    }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末漂佩,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子罪塔,更是在濱河造成了極大的恐慌投蝉,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,884評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件征堪,死亡現(xiàn)場(chǎng)離奇詭異瘩缆,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)佃蚜,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,755評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén)庸娱,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)着绊,“玉大人,你說(shuō)我怎么就攤上這事涌韩∨先幔” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 158,369評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵臣樱,是天一觀的道長(zhǎng)靶擦。 經(jīng)常有香客問(wèn)我,道長(zhǎng)雇毫,這世上最難降的妖魔是什么玄捕? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,799評(píng)論 1 285
  • 正文 為了忘掉前任,我火速辦了婚禮棚放,結(jié)果婚禮上枚粘,老公的妹妹穿的比我還像新娘。我一直安慰自己飘蚯,他們只是感情好馍迄,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,910評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著局骤,像睡著了一般攀圈。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上峦甩,一...
    開(kāi)封第一講書(shū)人閱讀 50,096評(píng)論 1 291
  • 那天赘来,我揣著相機(jī)與錄音,去河邊找鬼凯傲。 笑死犬辰,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的冰单。 我是一名探鬼主播幌缝,決...
    沈念sama閱讀 39,159評(píng)論 3 411
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼诫欠!你這毒婦竟也來(lái)了狮腿?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,917評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤呕诉,失蹤者是張志新(化名)和其女友劉穎缘厢,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體甩挫,經(jīng)...
    沈念sama閱讀 44,360評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡贴硫,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,673評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片英遭。...
    茶點(diǎn)故事閱讀 38,814評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡间护,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出挖诸,到底是詐尸還是另有隱情汁尺,我是刑警寧澤,帶...
    沈念sama閱讀 34,509評(píng)論 4 334
  • 正文 年R本政府宣布多律,位于F島的核電站痴突,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏狼荞。R本人自食惡果不足惜辽装,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,156評(píng)論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望相味。 院中可真熱鬧拾积,春花似錦、人聲如沸丰涉。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,882評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)一死。三九已至肛度,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間摘符,已是汗流浹背贤斜。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,123評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工策吠, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留逛裤,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,641評(píng)論 2 362
  • 正文 我出身青樓猴抹,卻偏偏與公主長(zhǎng)得像带族,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子蟀给,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,728評(píng)論 2 351

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