模板导出Excel

模板导出Excel使用POI模板导出Excel

大家好,又见面了,我是你们的朋友全栈君。

源码:

在Spring-Boot-Excel中POIExcel包中

依赖

<dependencies>

        <!-- https://mvnrepository.com/artifact/org.projectlombok/lombok -->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.16</version>
        </dependency>

        <!--        poi  -->
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>3.17</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>3.17</version>
        </dependency>

        <!--        web   -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

    </dependencies>

创建模板

说明:只参考(只是模板样式)

模板导出Excel

下载的工具包

**说明:**不用修改,详见DownloadUtil

package com.maizi.excel.POIExcel;

import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletResponse;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;

public class DownloadUtil { 
   

    /** * @param filePath 要下载的文件路径 * @param returnName 返回的文件名 * @param response HttpServletResponse * @param delFlag 是否删除文件 */
    protected void download(String filePath, String returnName, HttpServletResponse response, boolean delFlag) { 
   
        this.prototypeDownload(new File(filePath), returnName, response, delFlag);
    }


    /** * @param file 要下载的文件 * @param returnName 返回的文件名 * @param response HttpServletResponse * @param delFlag 是否删除文件 */
    protected void download(File file, String returnName, HttpServletResponse response, boolean delFlag) { 
   
        this.prototypeDownload(file, returnName, response, delFlag);
    }

    /** * @param file 要下载的文件 * @param returnName 返回的文件名 * @param response HttpServletResponse * @param delFlag 是否删除文件 */
    public void prototypeDownload(File file, String returnName, HttpServletResponse response, boolean delFlag) { 
   
        // 下载文件
        FileInputStream inputStream = null;
        ServletOutputStream outputStream = null;
        try { 
   
            if (!file.exists()) return;
            response.reset();
            //设置响应类型 PDF文件为"application/pdf",WORD文件为:"application/msword", EXCEL文件为:"application/vnd.ms-excel"。
            response.setContentType("application/octet-stream;charset=utf-8");

            //设置响应的文件名称,并转换成中文编码
            //returnName = URLEncoder.encode(returnName,"UTF-8");
            returnName = response.encodeURL(new String(returnName.getBytes(), "iso8859-1"));    //保存的文件名,必须和页面编码一致,否则乱码

            //attachment作为附件下载;inline客户端机器有安装匹配程序,则直接打开;注意改变配置,清除缓存,否则可能不能看到效果
            response.addHeader("Content-Disposition", "attachment;filename=" + returnName);

            //将文件读入响应流
            inputStream = new FileInputStream(file);
            outputStream = response.getOutputStream();
            int length = 1024;
            int readLength = 0;
            byte buf[] = new byte[1024];
            readLength = inputStream.read(buf, 0, length);
            while (readLength != -1) { 
   
                outputStream.write(buf, 0, readLength);
                readLength = inputStream.read(buf, 0, length);
            }
        } catch (Exception e) { 
   
            e.printStackTrace();
        } finally { 
   
            try { 
   
                outputStream.flush();
            } catch (IOException e) { 
   
                e.printStackTrace();
            }
            try { 
   
                outputStream.close();
            } catch (IOException e) { 
   
                e.printStackTrace();
            }
            try { 
   
                inputStream.close();
            } catch (IOException e) { 
   
                e.printStackTrace();
            }
            //删除原文件

            if (delFlag) { 
   
                file.delete();
            }
        }
    }

    /** * 2021-11-02 * * @param byteArrayOutputStream 将文件内容写入ByteArrayOutputStream * @param response HttpServletResponse 写入response * @param returnName 返回的文件名 */
    public void download(ByteArrayOutputStream byteArrayOutputStream, HttpServletResponse response, String returnName) throws IOException { 
   
        response.setContentType("application/octet-stream;charset=utf-8");
        returnName = response.encodeURL(new String(returnName.getBytes(), "iso8859-1"));            //保存的文件名,必须和页面编码一致,否则乱码
        response.addHeader("Content-Disposition", "attachment;filename=" + returnName);
        response.setContentLength(byteArrayOutputStream.size());

        ServletOutputStream outputstream = response.getOutputStream();    //取得输出流
        byteArrayOutputStream.writeTo(outputstream);                    //写到输出流
        byteArrayOutputStream.close();                                    //关闭
        outputstream.flush();                                            //刷数据
    }
}


/** * 三个参数 : ByteArrayOutputStream byteArrayOutputStream, * HttpServletResponse response, * String returnName 下载后的表名 */
      /* ByteArrayOutputStream outputStream = new ByteArrayOutputStream(); workbook.write(outputStream); new DownloadUtil().download(outputStream, response, "出货表.xlsx"); */

实体类

@Data
@AllArgsConstructor
@NoArgsConstructor
public class TemplateExcelData { 
   

    private String UUID;
    private String name;
    private String age;
    private String nickName;
    private String ip;
    private String birthday;
    private String card;
    private String remarks;

    // setter getter ……
}

controller

import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;

import javax.servlet.http.HttpServletResponse;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

@Controller
public class TemplateExcel { 
   

    @Autowired
    private HttpServletResponse response;


    //模板下载
    @GetMapping("/printExcel")
    public void printExcel(String inputDate) throws IOException { 
   
        //先调用service查询要打印的内容,这里先模拟数据
        List<TemplateExcelData> list = new ArrayList<>();
        list.add(new TemplateExcelData("20211102","王五","18","易烊千玺说我是他的小姑娘","192.168.0.123","2021-10-15","513436200011028752","千玺年的诗"));
        list.add(new TemplateExcelData("20211103","赵毛豆","25","会飞的猪","192.168.0.158","2021-11-15","513436200011026255","备注"));
        list.add(new TemplateExcelData("20211104","闻人萱","96","海豹突击队队长的烊烊","192.168.35.196","2021-12-15","513436200011027936","时倾_贰捌"));
        list.add(new TemplateExcelData("20211105","徐离伟","13","黑不溜秋的二十耶","10.168.0.123","2021-06-15","513436200011026837","烊烊不熬夜"));
        list.add(new TemplateExcelData("20211106","邹忠","52","我跟所有人都不熟","20.168.0.255","2021-05-23","513436200011029210","备注哦"));
        list.add(new TemplateExcelData("20211107","巩娇","06","易流年不复返","192.896.0.258","2021-01-23","513436200011027178","祁澜致,发给"));
        System.out.println("数据长度"+list.size());
        //先读取模板
        //1.获取模板的路径
        // String path = session.getServletContext().getRealPath("/") + "/xlsprint/tOUTPRODUCT.xlsx";
        String path = this.getClass().getClassLoader().getResource("xlsprint/tOUTPRODUCT.xlsx").getPath();
        //2.创建Workbook对象
        Workbook workbook = new XSSFWorkbook(path);
        //3.获取页
        Sheet sheetAt = workbook.getSheetAt(0);
        //4.处理大标题
        //获取标题行
        Row row = sheetAt.getRow(0);
        //获取标题单元格
        Cell cell = row.getCell(1);
        //设置标题内容
        inputDate = inputDate.replaceAll("-0", "-").replaceAll("-", "年");
        // 设置文件名称
        cell.setCellValue(inputDate + "用户表");
        //5.处理小标题行内容(小标题不改变,所以不用处理)
        //6.提取数据列的样式
        row = sheetAt.getRow(2);//获取数据的行
        CellStyle css[] = new CellStyle[9];//有8个单元格
        for (int i = 1; i < css.length; i++) { 
   
            cell = row.getCell(i);  //获取单元格
            css[i] = cell.getCellStyle();//获取样式
        }
        //7.填充数据
        int index = 2;
        for (TemplateExcelData productVo : list) { 
   
            row = sheetAt.createRow(index);//创建第3行,索引为2
            cell = row.createCell(1); //创建单元格
            cell.setCellValue(productVo.getUUID()); //设置内容
            cell.setCellStyle(css[1]); //样式
            /*一次类推*/
            cell = row.createCell(2);
            cell.setCellValue(productVo.getName());
            cell.setCellStyle(css[2]);
            cell = row.createCell(3);
            cell.setCellValue(productVo.getAge());
            cell.setCellStyle(css[3]);
            cell = row.createCell(4);
            cell.setCellValue(productVo.getNickName());
            cell.setCellStyle(css[4]);
            cell = row.createCell(5);
            cell.setCellValue(productVo.getIp());
            cell.setCellStyle(css[5]);
            cell = row.createCell(6);
            cell.setCellValue(productVo.getBirthday());
            cell.setCellStyle(css[6]);
            cell = row.createCell(7);
            cell.setCellValue(productVo.getCard());
            cell.setCellStyle(css[7]);
            cell = row.createCell(8);
            cell.setCellValue(productVo.getRemarks());
            cell.setCellStyle(css[8]);
            index++;
        }

        /** * 下载 * 三个参数 : ByteArrayOutputStream byteArrayOutputStream, * HttpServletResponse response, * String returnName */
        ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
        workbook.write(outputStream);
        new DownloadUtil().download(outputStream, response, inputDate + "月用户表.xlsx");
    }
}

测试

模板导出Excel

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/161514.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 高等数学学习目录

    高等数学学习目录第一章函数与极限第一节映射与函数初等函数双曲函数第二章导数的概念基本初等函数的倒数导数的四则运算第四章不定积分不定积分概念与性质天子骄龙

    2022年8月6日
    8
  • 音乐标签修改 android,音乐标签修改(Star Music Tag Editor)[通俗易懂]

    音乐标签修改 android,音乐标签修改(Star Music Tag Editor)[通俗易懂]StarMusicTagEditor可以对你音乐当中的各种标签信息来进行修改,在某些音乐信息出现错误之时你能够利用这款软件来直接的进行改正,让你的标签信息变得更加的容易进行分类,如果你感兴趣的话就快来下载这款StarMusicTagEditor!StarMusicTagEditor软件介绍StarMusicTagEditorPro「星空音乐标签编辑器」是一款可以帮助您修改…

    2022年7月25日
    8
  • 杭电OJ2058_杭电OJ

    杭电OJ2058_杭电OJ杭电OJ2058我写的超时了下面是不超时的#include<stdio.h>#include<math.h>intmain(){ intn,m,i,j; while(scanf(“%d%d”,&n,&m)!=EOF){ if(n==0&&m==0) break; for(j=(int)sqrt((double)(2*m));j>=1;j–){ i=(

    2022年10月2日
    0
  • java截取某个字符后面的字符串_java如何截取字符串

    java截取某个字符后面的字符串_java如何截取字符串提示:java截取某个字符之前或者之后的字符串文章目录一、java截取某个字符之前或者之后的字符串:1.截取”_”之前字符串2.截取”_”之后字符串二、截取正数第二个”_”后面的内容一、java截取某个字符之前或者之后的字符串:1.截取”_”之前字符串代码如下(示例)://java截取某个字符之前的字符串publicstaticvoidsubstringTest01(){Stringstr=”test_https://www.baidu.com/”;//截

    2022年10月7日
    0
  • Windows10 环境变量_环境变量与用户变量

    Windows10 环境变量_环境变量与用户变量Windows10环境变量(用户变量与系统变量)1.环境变量(environmentvariables)环境变量(environmentvariables)是在操作系统中用来指定操作系统运行环境的一些参数。环境变量是在操作系统中一个具有特定名字的对象,它包含了一个或者多个应用程序所将使用到的信息。Windows和DOS操作系统中的path环境变量,当要求系统运行一个程序而没有告诉它程序所在的完整路径时,系统除了在当前目录下面寻找此程序外,还应到path中指定的路径去找。用

    2022年9月17日
    0
  • 天才就是这样炼成的

    天才就是这样炼成的from 水木社区 天才就是这样炼成的——记菲尔兹奖获得者澳大利亚数学神童、陶哲轩作者:舒锋澳大利亚土生土长的华裔天才陶哲轩(TerrenceTao)于2006年年8月获得数学界的诺贝尔奖–菲尔兹奖(FieldsMedal)。国际数学会(IMU)每年在国际数学大会上颁菲尔兹奖给两至四名数学家,IMU表示,陶教授被颁这个殊荣,是因他对偏微分方程、组合数学、混合分析和堆垒素数论的杰出贡献。陶

    2022年5月8日
    36

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号