首页 > 编程语言 >数据导出简单处理:Java中导出excel数据!!!

数据导出简单处理:Java中导出excel数据!!!

时间:2024-06-23 13:56:51浏览次数:3  
标签:Java 导出 excel alibaba import annotation com response

达成的功能:查询出数据集合List,把集合内容导出成excel文件数据。

直接上代码:

1、pom.xml

            <!-- 阿里excel-->
            <dependency>
                <groupId>com.alibaba</groupId>
                <artifactId>easyexcel</artifactId>
                <version>3.0.2</version>
            </dependency>

2、代码

import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.net.URLEncoder;

public class EasyExcelUtils {
    public static HttpServletResponse getExcelResponse(HttpServletResponse response, String fileName) throws IOException {
        //防止乱码  
        fileName = URLEncoder.encode(fileName, "UTF-8");
        // Access-Control-Expose-Headers 暴露响应头在客户端
        response.setHeader("Access-Control-Expose-Headers", "Content-Disposition");
        response.addHeader("Content-disposition", "attachment;filename=" + fileName + ".xls");
        //设置头
        response.setHeader("Pragma", "No-cache");
        //设置头
        response.setHeader("Cache-Control", "no-cache");
        //设置日期头
        response.setDateHeader("Expires", 0);
        response.setContentType("application/msexcel;charset=UTF-8");
        return response;
    }
}
import com.alibaba.excel.metadata.Head;
import com.alibaba.excel.metadata.data.WriteCellData;
import com.alibaba.excel.write.metadata.holder.WriteSheetHolder;
import com.alibaba.excel.write.style.column.AbstractColumnWidthStyleStrategy;
import org.apache.poi.ss.usermodel.Cell;
import java.util.List;

public class CommonWidthHandler extends AbstractColumnWidthStyleStrategy {

    @Override
    protected void setColumnWidth(WriteSheetHolder writeSheetHolder, List<WriteCellData<?>> cellDataList, Cell cell, Head head, Integer relativeRowIndex, Boolean isHead) {
        if (Boolean.TRUE.equals(isHead)) {
            int columnWidth = cell.getStringCellValue().length();
            //默认10  最大255
            columnWidth = Math.max(columnWidth * 3, 10);
            if (columnWidth > 255) {
                columnWidth = 255;
            }
            writeSheetHolder.getSheet().setColumnWidth(cell.getColumnIndex(), columnWidth * 256);
        }
    }
}
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
import com.alibaba.excel.annotation.ExcelProperty;
import com.alibaba.excel.annotation.format.DateTimeFormat;
import com.alibaba.excel.annotation.write.style.ContentStyle;
import com.alibaba.excel.annotation.write.style.HeadFontStyle;
import com.alibaba.excel.annotation.write.style.HeadRowHeight;
import lombok.Data;
import java.util.Date;

@Data
@HeadFontStyle(fontHeightInPoints = 10)
@HeadRowHeight(20)
@ExcelIgnoreUnannotated
public class ExportVo {
    //@ExcelProperty是关键,这个里面的名字就是导出后的excel文件中的列的名字
    @ExcelProperty("列1")
    private String fieldOne;

    @DateTimeFormat("yyyy/MM/d")
    @ContentStyle(dataFormat = 0xe)
    @ExcelProperty(value = "日期XXX")
    private Date fieldTwo;
}
import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.ExcelWriter;
import com.alibaba.excel.write.metadata.WriteSheet;
import com.xxxxx.cms.interceptor.easyexcel.CommonWidthHandler;
import com.xxxxx.cms.utils.EasyExcelUtils;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiOperation;
import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource;
import javax.servlet.http.HttpServletResponse;
import java.util.List;

@RestController
@RequestMapping("/xxxxxxxxxxxx")
@Api(tags = "导出excel")
public class ExportExcelController {
    @Resource
    private ExportService exportService;

    @ApiImplicitParam(name = "参数名字", value = "参数说明", paramType = "body", dataType = "array", required = true)
    @ApiOperation("导入excle数据")
    @PostMapping(value = "/exportExcel")
    public void exportExcel(HttpServletResponse response, @RequestBody List<Integer> ids) {
        String tableName = "导出后的excel文件名字";
        ExcelWriter writer = null;
        try {
            //查询数据,ExportVo 类为业务中的实体类
            List<ExportVo> subtaskExportVoList = exportService.queryXxxx(ids);
            response = EasyExcelUtils.getExcelResponse(response, tableName);
            writer = EasyExcel.write(response.getOutputStream()).registerWriteHandler(new CommonWidthHandler()).build();
            WriteSheet projectSheet = EasyExcel.writerSheet(0, "excel表中sheet名字").head(ExportVo.class).build();
            writer.write(subtaskExportVoList, projectSheet);
        } catch (Exception exception) {
            throw new XxxException(exception.getMessage());
        } finally {
            if (writer != null) {
                writer.finish();
            }
        }
    }
}

效果如下:

success!!!

标签:Java,导出,excel,alibaba,import,annotation,com,response
From: https://blog.csdn.net/CSDN_MR_DAKE/article/details/139897997

相关文章

  • JavaSE 面向对象程序设计进阶 继承和方法重写 2024理论与内存详解
    继承面向对象三大特征:封装继承多态封装:对象代表什么,就封装对应的数据,并提供数据对应的行为,把零散的数据变成一个整体为什么要继承两个类中重复的代码(数据和方法)太多,所以要继承extend关键字类与类之间的父子关系让一个类和另一个类建立起继承关系publicclassStude......
  • JAVA【案例5-2】模拟默认密码自动生成
    【模拟默认密码自动生成】1、案例描述本案例要求编写一个程序,模拟默认密码的自动生成策略,手动输入用户名,根据用户名自动生成默认密码。在生成密码时,将用户名反转即为默认的密码。2、案例目的(1)学会分析“模拟默认密码的生成”案例的实现思路(2)根据思路完成“模拟默认密码的......
  • 微信小程序源码-基于Java后端的高校教务管理系统毕业设计(附源码+论文)
    大家好!我是程序员一帆,感谢您阅读本文,欢迎一键三连哦。......
  • JavaScript基础部分知识点总结(Part6)
    BOM概述1.什么是BOMBOM(BrowserObjectModel)即浏览器对象模型,它提供了独立于内容而与浏览器窗口进行交互的对象,其核心对象是window。BOM由一系列相关的对象构成,并且每个对象都提供了很多方法与属性。BOM缺乏标准,JavaScript语法的标准化组织是ECMA,DOM的标准化组织是W3C,BOM最......
  • 【VMware vSphere】使用RVTools中的PowerShell脚本创建导出vSphere环境信息的自动化任
    RVTools是VMware生态系统中一个非常受欢迎且免费的Windows实用工具,用于收集并显示VMwarevSphere环境中的相关信息,如虚拟机、主机及集群等相关配置。RVTools利用VMwarevSphereManagementSDK8.0和CISRESTAPI提供的丰富数据来直接获取和收集信息,这在管理员对VMwa......
  • java基于ssm+jsp 母婴用品网站
    1管理员功能模块管理员登录,管理员通过输入用户名、密码等信息进行系统登录,如图1所示。图1管理员登录界面图管理员登录进入母婴用品网站可以查看主页、个人中心、用户管理、商品分类管理、商品信息管理、留言板管理、成长交流、系统管理、订单管理、留言管理等内容,如图2所......
  • 大学生HTML期末大作业——HTML+CSS+JavaScript游戏网站(Epic)
    HTML+CSS+JS【游戏网站】网页设计期末课程大作业web前端开发技术web课程设计网页规划与设计......
  • 大学生HTML期末大作业——HTML+CSS+JavaScript购物商城(电子器件)
    HTML+CSS+JS【购物商城】网页设计期末课程大作业web前端开发技术web课程设计网页规划与设计......
  • SpringBoot前后端传递数据时常用的JSON格式数据是什么?【讲解JSON概念、语法、以及Java
    SpringBoot前后端传递数据时常用的JSON格式数据是什么?JSON概念JSON语法JSON的两种结构:JSON字符串和Java对象互转:objectMapper.writeValueAsString(person);objectMapper.readValue(jsonStr,Person.class);在SpringMVC框架中,前后端交互会自动转JsonJSON概念JSON:Jav......
  • JAVA高级进阶09
    第九天、IO流IO流-字符流文件字符输入流-读字符数据进来FileReader(文件字符输入流)作用:以内存为基准,可以把文件中的数据以字符的形式读入到内存中去。文件字符输出流-写字符数据出去FileWriter(文件字符输出流)作用:以内存为基准,把内存中的数据以字符的形式写出到文件......