国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

EasyExcel動態(tài)表頭導出(支持多級表頭)

這篇具有很好參考價值的文章主要介紹了EasyExcel動態(tài)表頭導出(支持多級表頭)。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

EasyExcel動態(tài)表頭導出(支持多級表頭)

在很多業(yè)務場景中,都會應用到動態(tài)表頭的導出,也會涉及到多級表頭的導出,如下圖所示

通過EasyExcel,我們可以快速實現(xiàn)這一需求,具體代碼如下

maven依賴

<dependency>
  <groupId>com.alibaba</groupId>
  <artifactId>easyexcel</artifactId>
  <version>2.2.6</version>
</dependency>

DynamicHeader.java

import java.util.List;

/**
 *@Author: <a href="mailto:fxsen@foxmail.com">Fxsen</a>
 *@CreateTime: 2023年09月22日  09:16
 */
public class DynamicHeader {
    /**
     * 要導出的字段名稱英文
     */
    private String fieldName;

    /**
     * 要導出的表頭名稱中文
     */
    private String headName;
    /**
     * 如果是多級表都,插入下級
     */
    private List<DynamicHeader> children;

    public String getFieldName() {
        return fieldName;
    }

    public void setFieldName(String fieldName) {
        this.fieldName = fieldName;
    }

    public String getHeadName() {
        return headName;
    }

    public void setHeadName(String headName) {
        this.headName = headName;
    }

    public List<DynamicHeader> getChildren() {
        return children;
    }

    public void setChildren(List<DynamicHeader> children) {
        this.children = children;
    }
}

CustomTitleWriteHandler.java

import com.alibaba.excel.write.handler.SheetWriteHandler;
import com.alibaba.excel.write.metadata.holder.WriteSheetHolder;
import com.alibaba.excel.write.metadata.holder.WriteWorkbookHolder;
import org.apache.poi.ss.usermodel.CellStyle;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.ss.util.CellRangeAddress;

public class CustomTitleWriteHandler implements SheetWriteHandler {
    /**
     * 標題
     */
    private final String fileName;

    /**
     * 字段個數(shù)
     */
    private final Integer count;

    public CustomTitleWriteHandler(Integer count,String fileName) {
        this.fileName = fileName;
        this.count = count;
    }

    @Override
    public void beforeSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) {

    }

    @Override
    public void afterSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) {
        // 獲取clazz所有的屬性
        Workbook workbook = writeWorkbookHolder.getWorkbook();
        Sheet sheet = workbook.getSheetAt(0);
        Row row1 = sheet.createRow(0);
        row1.setHeight((short) 800);
        Cell cell = row1.createCell(0);
        //設置標題
        cell.setCellValue(fileName);
        CellStyle cellStyle = workbook.createCellStyle();
        cellStyle.setBorderBottom(BorderStyle.THIN); //下邊框
        cellStyle.setBorderLeft(BorderStyle.THIN);//左邊框
        cellStyle.setBorderTop(BorderStyle.THIN);//上邊框
        cellStyle.setBorderRight(BorderStyle.THIN);//右邊框
        cellStyle.setVerticalAlignment(VerticalAlignment.CENTER);
        cellStyle.setAlignment(HorizontalAlignment.CENTER);
        Font font = workbook.createFont();
        font.setBold(true);
        font.setFontHeight((short) 400);
        font.setFontName("宋體");
        cellStyle.setFont(font);
        cell.setCellStyle(cellStyle);
        CellRangeAddress region = new CellRangeAddress(0, 0, 0, count - 1);
        setRegionStyle(sheet,region,cellStyle);
        sheet.addMergedRegion(region);
    }
    /**
     * 為合并的單元格設置樣式(可根據(jù)需要自行調整)
     */
    public static void setRegionStyle(Sheet sheet, CellRangeAddress region, CellStyle cs) {
        for (int i = region.getFirstRow(); i <= region.getLastRow(); i++) {
            Row row = sheet.getRow(i);
            if (null == row) row = sheet.createRow(i);
            for (int j = region.getFirstColumn(); j <= region.getLastColumn(); j++) {
                Cell cell = row.getCell(j);
                if (null == cell) cell = row.createCell(j);
                cell.setCellStyle(cs);
            }
        }
    }
}

CellStyle.java

import com.alibaba.excel.metadata.CellData;
import com.alibaba.excel.metadata.Head;
import com.alibaba.excel.write.metadata.holder.WriteSheetHolder;
import com.alibaba.excel.write.style.column.AbstractColumnWidthStyleStrategy;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Sheet;

import java.util.List;

public class CellStyle extends AbstractColumnWidthStyleStrategy {

    @Override
    protected void setColumnWidth(WriteSheetHolder writeSheetHolder, List<CellData> cellDataList, Cell cell, Head head,
                                  Integer relativeRowIndex, Boolean isHead) {
        // 簡單設置
        Sheet sheet = writeSheetHolder.getSheet();
        sheet.setColumnWidth(cell.getColumnIndex(), 5000);
    }

}

DynamicExcelUtils.java文章來源地址http://www.zghlxwxcb.cn/news/detail-712105.html

import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.lang.reflect.Field;
import java.net.URLEncoder;
import java.nio.charset.StandardCharsets;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;
import java.util.*;
import java.util.stream.Collectors;
import cn.hutool.core.util.ReflectUtil;
import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.EasyExcelFactory;
import com.alibaba.excel.ExcelWriter;
import com.alibaba.excel.write.metadata.WriteSheet;
import com.alibaba.excel.write.metadata.fill.FillConfig;
import com.wisesoft.core.util.DateUtil;
import org.apache.commons.collections4.CollectionUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletResponse;
/**
 * 動態(tài)導出工具
 *@Author: <a href="mailto:fxsen@foxmail.com">Fxsen</a>
 *@CreateTime: 2023年09月22日  09:13
 */
public class DynamicExcelUtils {
    private static final Logger log = LoggerFactory.getLogger(DynamicExcelUtils.class);

    /**
     * 根據(jù)模板導出數(shù)據(jù) 單個sheet
     *
     * @param response     返回對象
     * @param dataList     導出的數(shù)據(jù)集合
     * @param object       填充對象
     * @param fileName     文件名稱
     * @param templateName 模板名稱
     * @throws Exception
     */
    public void exportTemplateExcel(HttpServletResponse response, List<?> dataList, Object object,
                                    String fileName, String templateName) throws Exception {
        InputStream inputStream = this.getClass().getResourceAsStream(templateName);
        FillConfig fillConfig = FillConfig.builder().forceNewRow(Boolean.TRUE).build();
        ExcelWriter excelWriter = EasyExcelFactory.write(getOutputStream(fileName, response)).withTemplate(inputStream).build();
        WriteSheet writeSheet0 = EasyExcelFactory.writerSheet(0).build();
        excelWriter.fill(object, fillConfig, writeSheet0);
        excelWriter.fill(dataList, fillConfig, writeSheet0);
        excelWriter.finish();
    }

    /**
     * 構建輸出流
     *
     * @param fileName 文件名稱
     * @param response 輸出流
     * @return
     * @throws Exception
     */
    private OutputStream getOutputStream(String fileName, HttpServletResponse response) throws Exception {
        fileName = URLEncoder.encode(fileName, StandardCharsets.UTF_8.name()).replaceAll("\\+", "%20");
        response.setContentType("application/vnd.ms-excel");
        response.setCharacterEncoding(StandardCharsets.UTF_8.name());
        response.setHeader("Content-Disposition", "attachment;filename=" + fileName + ".xlsx");
        return response.getOutputStream();
    }
    /**
     * 動態(tài)表頭生成excel
     * @param headers 要生成的表頭
     * @param dataList 數(shù)據(jù)
     * @param response
     * @param fileName 文件名稱
     * @param titleName title名稱
     * @param <T>
     */
    public static <T> void dynamicExportExcel(List<DynamicHeader> headers, List<T> dataList, HttpServletResponse response, String fileName, String titleName) {
        long startTime = System.currentTimeMillis();
        List<List<T>> allList = new ArrayList<>();
        if (CollectionUtils.isNotEmpty(dataList)){
            for (T detail : dataList) {
                allList.addAll(dataList(headers, detail));
            }
        }
        List<List<String>> headerList = headers(headers);
        try (ServletOutputStream outputStream = response.getOutputStream()) {
            String name = URLEncoder.encode(fileName, StandardCharsets.UTF_8.name()).replaceAll("\\+", "%20");
            response.setContentType("application/vnd.ms-excel");
            response.setCharacterEncoding("utf-8");
            response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + name + ".xlsx");//設置響應頭
            EasyExcel.write(outputStream).head(headerList)
                    //表格標題占位
                    .relativeHeadRowIndex(1)
                    //文件樣式
                    .registerWriteHandler(new CustomTitleWriteHandler(headerList.size(),titleName))
                    .registerWriteHandler(new CellStyle())
                    .sheet(fileName).doWrite(allList);
        } catch (IOException e) {
            e.printStackTrace();
            log.error("生成動態(tài)EXL失敗,字段", e);
        }
        long endTime = System.currentTimeMillis();
        log.info("動態(tài)導出耗時:{}", endTime - startTime);
    }

    //excel表頭
    public static List<List<String>> headers(List<DynamicHeader> excelHeaders) {
        List<List<String>> headers = new ArrayList<>();
        for (DynamicHeader header : excelHeaders) {
            List<DynamicHeader> children = header.getChildren();
            if (CollectionUtils.isNotEmpty(children)){
                for (DynamicHeader child : children) {
                    List<String> head = new ArrayList<>();
                    head.add(header.getHeadName());
                    head.add(child.getHeadName());
                    headers.add(head);
                }
            }else {
                List<String> head = new ArrayList<>();
                head.add(header.getHeadName());
                headers.add(head);
            }
        }
        return headers;
    }

    /**
     * 要導出的字段
     *
     * @param exportFields 表頭集合
     * @param obj          數(shù)據(jù)對象
     * @return 集合
     */
    public static <T> List<List<T>> dataList(List<DynamicHeader> exportFields, T obj) {
        List<List<T>> list = new ArrayList<>();
        List<T> data = new ArrayList<>();
        List<String> propList = new ArrayList<>();
        for (DynamicHeader exportField : exportFields) {
            List<DynamicHeader> children = exportField.getChildren();
            if (CollectionUtils.isNotEmpty(children)){
                propList.addAll(children.stream().map(DynamicHeader::getFieldName).collect(Collectors.toList()));
            }else {
                propList.add(exportField.getFieldName());
            }
        }
        if (obj instanceof Map){
            Map map = (Map) obj;
            for (String prop : propList) {
                map.forEach((k,v)->{
                    if (prop.equals(k)){
                        if (Objects.isNull(v)){
                            v = "";
                        }else if (v instanceof Date){
                            v = DateUtil.format((Date)v,DateUtil.DATETIME_YMD_DASH);
                        }
                        data.add((T)v);
                    }
                });
            }
        }else {
            //先根據(jù)反射獲取實體類的class對象
            Class<?> objClass = obj.getClass();
            //設置實體類屬性的集合
            Field[] fields = ReflectUtil.getFields(objClass);
            for (String prop : propList) {
                //循環(huán)實體類對象集合
                for (Field field : fields) {
                    field.setAccessible(true);
                    //判斷實體類屬性跟特定字段集合名是否一樣
                    if (field.getName().equals(prop)) {
                        T object = null;
                        try {
                            object = (T) field.get(obj);
                        } catch (IllegalAccessException e) {
                            e.printStackTrace();
                            log.error("生成動態(tài)EXL失敗,字段", e);
                        }
                        //獲取屬性對應的值
                        if(null == object){
                            object = (T) "";
                        }else{
                            if(object instanceof LocalDate){
                                object = (T)((LocalDate)object).format(DateTimeFormatter.ofPattern(DateUtil.DEFAULT_DATETIME_FORMAT));
                            }
                            if(object instanceof LocalDateTime){
                                object = (T) ((LocalDateTime)object).format(DateTimeFormatter.ofPattern(DateUtil.DEFAULT_DATETIME_FORMAT));
                            }
                        }
                        data.add(object);
                    }
                }
            }
        }
        list.add(data);
        return list;
    }
}

測試:

到了這里,關于EasyExcel動態(tài)表頭導出(支持多級表頭)的文章就介紹完了。如果您還想了解更多內容,請在右上角搜索TOY模板網以前的文章或繼續(xù)瀏覽下面的相關文章,希望大家以后多多支持TOY模板網!

本文來自互聯(lián)網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。如若轉載,請注明出處: 如若內容造成侵權/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經查實,立即刪除!

領支付寶紅包贊助服務器費用

相關文章

  • 【EasyExcel】導出excel凍結表頭和凍結指定列并支持篩選器

    【EasyExcel】導出excel凍結表頭和凍結指定列并支持篩選器

    需求背景: ? ? ? ? 導出excel的同時凍結表頭和前兩列基礎信息,方便導出后用戶查看信息。 一、技術選型: ? ? ? ? easyExcel的自定義寫策略處理:SheetWriteHandler 二、方案設計:(基于實現(xiàn) SheetWriteHandler 接口) ? ? ? ? 1、重寫afterSheetCreate(WriteWorkbookHolder writeWorkbookHolder,

    2024年01月24日
    瀏覽(31)
  • java poi實現(xiàn)Excel多級表頭導出

    java poi實現(xiàn)Excel多級表頭導出

    最近碰到一個導出,比較繁瑣,也查詢了許多博客,在其中一篇博客的基礎上修改,實現(xiàn)了最終想要的效果。話不多說,直接上效果圖 1.主代碼: 2.合并單元格 3.設置表頭單元格的寬度 4.填充數(shù)據(jù)(注:我這里的數(shù)據(jù)格式是ListMapString, Object類型,可以根據(jù)自己的實際情況來封

    2024年02月03日
    瀏覽(47)
  • EasyExcel復雜表頭導出(一對多)升級版

    EasyExcel復雜表頭導出(一對多)升級版

    ????????在之前寫的?EasyExcel復雜表頭導出(一對多)的博客的結尾,受限于當時的能力和精力,留下一些問題及展望。現(xiàn)在寫下此博客,目的就是解決之前遺留的問題。 ? ? ? ? 背景介紹,見上述鏈接指向的博客,這里主要通過 自定義攔截器 的形式來完美解決。 對于圖

    2024年02月06日
    瀏覽(21)
  • JAVA(EasyExcel)通過遠程調用模板 導出數(shù)據(jù) 復雜表頭

    JAVA(EasyExcel)通過遠程調用模板 導出數(shù)據(jù) 復雜表頭

    最近接手一個需求,單組數(shù)據(jù)的顯示,也有多組數(shù)據(jù)的顯示,查了好多文章,都不是很明白.但是這篇文章和我的需求差不多非常相似(鏈接放在文末),根據(jù)這篇文章然后將自己的實現(xiàn)過程記錄了下來,以防之后再用到. 這是我需要導出的excel格式 開頭是單條數(shù)據(jù)的展示 之后是多條數(shù)據(jù)

    2024年02月03日
    瀏覽(32)
  • Element UI動態(tài)生成多級表頭

    Element UI動態(tài)生成多級表頭

    我們常常遇到的情況就是表頭固定的,我們需要從后端獲取對應表頭的信息,如果信息比較多的時候為了方便我們展示,可以固定表頭和列,下面是一個我們常見的例子: 固定列和表頭可以同時使用,只需要將上述兩個屬性分別設置好即可。 前端顯示: ? 代碼實現(xiàn) ? ? ?

    2024年02月11日
    瀏覽(25)
  • 前端vue+elementui導出復雜(單元格合并,多級表頭)表格el-table轉為excel導出

    前端vue+elementui導出復雜(單元格合并,多級表頭)表格el-table轉為excel導出

    需求 :前端對el-table表格導出 插件 : npm install xlsx -S npm install file-saver --save 原理 :直接導出el-table的表格里面的數(shù)據(jù),這樣就會存在缺點,只會導出當前頁面的數(shù)據(jù),如果需要導出全部數(shù)據(jù),可以自己重新渲染一個全部數(shù)據(jù)不可見的el-table表格,來導出就可以了 擴展 :經過

    2024年02月04日
    瀏覽(31)
  • easyExcel生成動態(tài)表頭

    easyExcel生成動態(tài)表頭

    如圖,問題是可以根據(jù)數(shù)據(jù)自動生成的,只是舉了個栗子,可以把表頭headers和內容contents根據(jù)數(shù)據(jù)來生成

    2024年02月14日
    瀏覽(17)
  • Vue動態(tài)多級表頭+行列合計+可編輯表格

    新建組件:Table.vue 新建組件: 可參考鏈接 https://blog.csdn.net/weixin_45275107/article/details/127509100 https://blog.csdn.net/weixin_39166851/article/details/130765957 https://blog.csdn.net/m0_67841039/article/details/131308126 https://blog.csdn.net/weixin_40881970/article/details/124699566

    2024年02月16日
    瀏覽(24)
  • vue element-ui表格組件動態(tài)多級表頭

    vue element-ui表格組件動態(tài)多級表頭

    實際項目的需求,需要根據(jù)后端動態(tài)獲取的方式來初始化表格的表頭包含哪些信息,且有很多信息是有規(guī)律的,所以我們需要Element UI動態(tài)生成多級表頭。需要的效果圖如下: 由于統(tǒng)計維度是可變化的(它可以是省市也可以是區(qū)縣),所以需要專門設置一個表格的數(shù)據(jù)來保存

    2024年02月10日
    瀏覽(32)
  • el-table動態(tài)生成多級表頭的表格(js + ts)

    el-table動態(tài)生成多級表頭的表格(js + ts)

    展示形式: 詳細代碼: (js) (ts)

    2024年02月10日
    瀏覽(92)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領取紅包,優(yōu)惠每天領

二維碼1

領取紅包

二維碼2

領紅包