springBoot中Excel导出

29 篇文章 0 订阅
17 篇文章 0 订阅
依赖
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
    <version>3.10.1</version>
</dependency>
//工具类

package com.sk.springboot.Util;

import org.apache.poi.hssf.usermodel.*;
import org.apache.poi.hssf.util.HSSFColor;

public class ExcelWriteUtil {
    public static HSSFWorkbook getHSSFWorkbook(String sheetName, String []title, String [][]values, HSSFWorkbook wb){
        if(wb == null){
            wb = new HSSFWorkbook();
        }
        HSSFSheet sheet = wb.createSheet(sheetName);
        HSSFRow row = sheet.createRow(0);
        HSSFCellStyle style = wb.createCellStyle();
        HSSFFont font=wb.createFont();
        font.setColor(HSSFColor.BLACK.index);//字体颜色
        font.setFontHeightInPoints((short)12);
        font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);//字体增粗
        style.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 创建一个居中格式
        style.setFont(font);

        HSSFCell cell = null;
        //创建标题
        for(int i=0;i<title.length;i++){
            cell = row.createCell(i);
            cell.setCellValue(title[i]);
            cell.setCellStyle(style);
        }
        //创建内容
        for(int i=0;i<values.length;i++){
            row = sheet.createRow(i + 1);
            for(int j=0;j<values[i].length;j++){
                row.createCell(j).setCellValue(values[i][j]);
            }
        }
        return wb;
    }
}
//测试实现类

package com.sk.springboot.Util;

import com.feibo.shikai.springboot.domain.UserD;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import javax.servlet.http.HttpServletResponse;
import java.io.OutputStream;
import java.net.URLEncoder;
import java.util.ArrayList;
import java.util.List;

public class ExcelTest {

    public  void exportExcelApiInterfaceLog(HttpServletResponse response) {
        String filename = "ExcelName.xls";
        try {
            this.setResponseHeader(response,filename);
            HSSFWorkbook wb=this.writeExcel();
            OutputStream os = response.getOutputStream();
            wb.write(os);
            os.flush();
            os.close();
        } catch (Exception e) {
           e.printStackTrace();
        }
    }
    public void setResponseHeader(HttpServletResponse response, String fileName) {
        try {
            response.setContentType("application/force-download");
            response.setHeader("Content-Disposition", "attachment;filename="+  URLEncoder.encode(fileName, "UTF-8"));
        } catch (Exception ex) {
            ex.printStackTrace();
        }
    }
    public  HSSFWorkbook writeExcel(){
//需要写入的实体类,此处我模拟一个实体类
        UserD u =new UserD();
        u.setId(1L);
        u.setName("sk");
        u.setPwd("123");
        u.setAccount("234");

        List userList = new ArrayList();
        userList.add(u);

        String sheetName="ExcelSheet-Name";
        String[][] values = new String[userList.size()][];
        String[] titles = null;
        titles= new String[]{"id","name","pwd","account"};
            for (int i = 0; i <userList.size() ; i++) {
                values[i] = new String[titles.length];
                //将对象内容转换成string
                UserD obj = (UserD) userList.get(i);
                values[i][0] = obj.getId().toString();
                values[i][1] = obj.getName();
                values[i][2] = obj.getPwd();
                values[i][3] = obj.getAccount();
            }
        HSSFWorkbook wb=ExcelWriteUtil.getHSSFWorkbook(sheetName,titles,values,null);
        return wb;
    }

}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是SpringBoot整合EasyExcel模板导出Excel的步骤: 1.创建SpringBoot项目 2.在pom.xml文件添加EasyExcel依赖 ```xml <dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</artifactId> <version>2.1.6</version> </dependency> ``` 3.创建Excel模板 4.编写实体类,用于映射Excel的数据 5.编写Excel导出工具类 ```java public class ExcelUtil { /** * 导出 Excel :一个 sheet,带表头. * * @param sheetName sheet 名称 * @param clazz 实体类对象,通过 annotation 设置标题 * @param data 实体类对象数据 list * @param out 输出流 */ public static void exportExcel(String sheetName, Class clazz, List data, OutputStream out) { ExcelWriter writer = EasyExcelFactory.getWriter(out); //写第一个sheet,sheet1 数据全是List<String> 无模型映射关系 Sheet sheet = new Sheet(1, 0, clazz); sheet.setSheetName(sheetName); //设置自适应宽度 sheet.setAutoWidth(Boolean.TRUE); //写数据到 Writer 上下文 writer.write(data, sheet); //将上下文的最终 outputStream 写入到指定文件 writer.finish(); } } ``` 6.在Controller调用Excel导出工具类 ```java @GetMapping("/export") public void export(HttpServletResponse response) throws IOException { //查询数据 List<User> userList = userService.getUserList(); //设置文件名 String fileName = "用户信息表"; //设置响应头 response.setContentType("application/vnd.ms-excel"); response.setCharacterEncoding("utf-8"); response.setHeader("Content-disposition", "attachment;filename=" + URLEncoder.encode(fileName, "UTF-8") + ".xlsx"); //导出Excel ExcelUtil.exportExcel(fileName, User.class, userList, response.getOutputStream()); } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值