java使用poi导出excel

这篇博客介绍了如何使用Apache POI库在Java中生成Excel文件进行数据导出。首先,添加了Apache POI的依赖。然后,提供了一个名为`ExcelUtil`的工具类,该类包含一个`write`方法,用于根据输入的工作表数据列表创建并下载Excel文件。这个方法设置列头样式,处理行高和列宽,并填充数据。最后,展示了如何调用`ExcelUtil`来导出用户数据到Excel表格。
摘要由CSDN通过智能技术生成

1、项目依赖

<!-- Excel导出 -->
<dependency>
    <groupId>org.apache.poi</groupId>
	<artifactId>poi-examples</artifactId>
	<version>4.1.2</version>
</dependency>

2、工具类

package com.taxi.common.utils;

import lombok.Data;
import org.apache.poi.hssf.usermodel.*;
import org.apache.poi.ss.usermodel.HorizontalAlignment;
import org.apache.poi.ss.usermodel.IndexedColors;
import org.apache.poi.ss.usermodel.VerticalAlignment;

import javax.servlet.http.HttpServletResponse;
import java.io.OutputStream;
import java.util.List;

public class ExcelUtil {

    @Data
    public class SheetData {

        //工作表名称
        public String sheetName;

        //表头
        public List<String> columnList;

        //表数据
        public List<String[]> dataList;
    }

    /**
     * 下载Excel
     * @param sheetDataList 工作表
     * @param fileName 文件名
     */
    public void write(List<SheetData> sheetDataList,
                      String fileName,
                      HttpServletResponse response){
        try {
            //excel的工作簿
            HSSFWorkbook wb = new HSSFWorkbook();

            //基本数据工作表创建
            for(SheetData sheetData : sheetDataList){
                HSSFSheet sheet = wb.createSheet(sheetData.getSheetName());

                // 设置表头字体样式
                HSSFFont columnHeadFont = wb.createFont();
                columnHeadFont.setFontName("宋体");
                columnHeadFont.setFontHeightInPoints((short) 10);
                columnHeadFont.setBold(true);

                // 列头的样式
                HSSFCellStyle columnHeadStyle = wb.createCellStyle();
                columnHeadStyle.setFont(columnHeadFont);
                // 左右居中
                columnHeadStyle.setAlignment(HorizontalAlignment.CENTER);
                // 上下居中
                columnHeadStyle.setVerticalAlignment(VerticalAlignment.CENTER);
                columnHeadStyle.setLocked(true);
                columnHeadStyle.setWrapText(true);
                // 设置单元格的背景颜色(单元格的样式会覆盖列或行的样式)
                columnHeadStyle.setFillForegroundColor(IndexedColors.WHITE.index);

                // 设置普通单元格字体样式
                HSSFFont font = wb.createFont();
                font.setFontName("宋体");
                font.setFontHeightInPoints((short) 10);

                //列宽
                for (int i=0;i<sheetData.columnList.size()+1;i++){
                    //默认列宽
                    Integer cellWidth=3500;
                    sheet.setColumnWidth(i,cellWidth);
                }

                //创建Excel工作表第一行
                HSSFRow row0 = sheet.createRow(0);
                // 设置行高
                row0.setHeight((short) 750);
                HSSFCell nCell=null;
                for (int i=0;i<sheetData.columnList.size();i++){
                    nCell = row0.createCell(i);
                    //设置单元格内容
                    nCell.setCellValue(sheetData.columnList.get(i));
                    //设置单元格字体样式
                    nCell.setCellStyle(columnHeadStyle);
                }

                //循环写入数据
                for (int j=0;j<sheetData.getDataList().size();j++){
                    String[] arr = sheetData.getDataList().get(j);
                    //创建行
                    HSSFRow nRow = sheet.createRow(j + 1);
                    //内容
                    for (int i=0;i<sheetData.columnList.size();i++){
                        nCell = nRow.createCell(i);
                        nCell.setCellValue(arr[i]);
                        nCell.setCellStyle(columnHeadStyle);
                    }

                }
            }

            // 获取输出流
            OutputStream output=response.getOutputStream();
            // 重置输出流
            response.reset();
            // 设定输出文件头,并处理中文乱码
            response.setHeader( "Content-Disposition", "attachment;filename="
                    +fileName);
            // 定义输出类型
            response.setContentType("application/vnd.ms-excel");
            wb.write(output);
            output.close();
        }catch (Exception e){
            e.printStackTrace();
        }
    }
}

3、使用

 public void exportLog(HttpServletResponse response) {
        //查询需要导出的数据
        List<User> list = userMapper.selectByCondition();

        //表头
        List<String> columnList = Arrays.asList("姓名", "年龄");

        //数据
        List<String[]> dataList = new ArrayList<>();
        for (User user : list) {
            String[] arr = new String[2];
            arr[0] = user.getName();
            arr[1] = user.getAge().toString();
            dataList.add(arr);
        }
      
        //导出
        List<ExcelUtil.SheetData> sheetDataList = new ArrayList<>();
        ExcelUtil excelUtil = new ExcelUtil();
        ExcelUtil.SheetData sheetData = excelUtil.new SheetData();
        sheetData.setSheetName("user");
        sheetData.setColumnList(columnList);
        sheetData.setDataList(dataList);
        sheetDataList.add(sheetData);
        String fileName = "user.xls";
        excelUtil.write(sheetDataList, fileName, response);
    }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值
>