java导出excel,excel表头映射到javaBean属性名称等

本文介绍如何在Java中导出Excel文件,并将Excel表头映射到JavaBean的属性名称。同时,文章指出当遇到Date类型数据时,可能会被误识别为Long类型数字进行输出的问题。
摘要由CSDN通过智能技术生成

一、pom依赖

        <org.apache.poi.version>3.10-FINAL</org.apache.poi.version>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>${org.apache.poi.version}</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>${org.apache.poi.version}</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml-schemas</artifactId>
            <version>${org.apache.poi.version}</version>
        </dependency>

 

二、封装的服务

import cn.hutool.core.util.ObjectUtil;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import lombok.extern.slf4j.Slf4j;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import tf56.hermescontractweb.util.DateUtil;
​
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletResponse;
import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.Map;
import java.util.UUID;
​
@Slf4j
@Service
public class ExcelExportService {
​
    @Autowired
    private HermesFileService hermesFileService;
​
    /**
     * 导出excel
     * @param excelDataList:需要导出的数据 List<javaBean>
     * @param clazz 对应excelDataList具体类型的clazz(导出excel表头使用javaBean属性名)
     * @param response
     * @throws Exception
     */
    public void exportExcel2003(List excelDataList, Class clazz, HttpServletResponse response) throws Exception {
        List<String> excelTitles = getExcelTitles(clazz);
        List<Map<String, Object>> rowDataList = new ArrayList<>();
        for (Object obj : excelDataList) {
            rowDat
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值