模板导出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

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • eclipse安装教程完整版

    eclipse安装教程完整版eclipse安装教程完整版安装Java教程安装eclipse教程安装Tomcat教程安装MySQL数据库教程安装Java教程到官网下载Java,这里推荐下载JavaSE8下载完成后点击安装,然后一直下一步,注意安装路径不要出现中文,不然可能会出错接下来配置环境变量,先找到Java的安装路径并复制路径右击计算机(没有计算机就右击此电脑)选择属性,点击高级系统设置,然后在高级下面选择环境变量这里有两种配置方法一种是采用绝对路径,一种是采用相对路径绝对路径:(推荐使用)选中系统变量中变量

  • stringtokenizer java,Java中的StringTokenizer「建议收藏」

    stringtokenizer java,Java中的StringTokenizer「建议收藏」Java中的StringTokenizerjava.util.StringTokenizer类允许您将字符串分成令牌。这是打破字符串的简单方法。它没有提供区分数字,带引号的字符串,标识符等的功能,例如StreamTokenizer类。我们将在I/O一章中讨论StreamTokenizer类。StringTokenizer类的构造方法StringTokenizer类中定义了3个构造函数。Constr…

  • 必知必会 RabbitMQ面试题 33道(附答案)「建议收藏」

    必知必会 RabbitMQ面试题 33道(附答案)「建议收藏」点击关注公众号,回复000获取优质资料前言大家好,我是老田。今天我们来分享RabbitMQ消息队列。其中,MQ(MessageQueue)翻译过来就是消息队列的意思。RabbitMQ…

  • MLP多层感知机(人工神经网络)原理及代码实现

    MLP多层感知机(人工神经网络)原理及代码实现一、多层感知机(MLP)原理简介多层感知机(MLP,MultilayerPerceptron)也叫人工神经网络(ANN,ArtificialNeuralNetwork),除了输入输出层,它中间可以有多个隐层,最简单的MLP只含一个隐层,即三层的结构,如下图:从上图可以看到,多层感知机层与层之间是全连接的(全连接的意思就是:上一层的任何一个神经元与下一层的所有神经元都有连接)。多层感知机最底层…

  • 脚手架专项施工方案范本_脚手架工程施工方案主要内容

    脚手架专项施工方案范本_脚手架工程施工方案主要内容前言如何快速搭建一个httprunner项目呢?我们可以使用脚手架,脚手架就是自动地创建一些目录,形成一个项目的架构,不需要我们再手动的去创建查看创建新项目的命令先来查看一下帮助命令httpr

  • 多层感知机实现(单层感知器和多层感知器)

    前面利用了softmax来对图像进行分类,也可以使用多层感知机的方法对图像进行分类。多层感知机从零开始实现方法多层感知机(multilayerperceptron,MLP),在单层神经网络的基础上引入了一到多个隐藏层(hiddenlayer)。对于图中的感知机来说,它含有一个隐藏层,该层中有5个隐藏单元。输入和输出个数分别为4和3,中间的隐藏层中包含了5个隐藏单元。…

发表回复

您的电子邮箱地址不会被公开。

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