All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.litongjava.table.utils.EasyExcelUtils Maven / Gradle / Ivy

There is a newer version: 1.4.8
Show newest version
package com.litongjava.table.utils;

import java.io.IOException;
import java.io.OutputStream;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.Set;

import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.ExcelWriter;
import com.alibaba.excel.write.builder.ExcelWriterBuilder;
import com.alibaba.excel.write.metadata.WriteSheet;
import com.alibaba.excel.write.style.column.LongestMatchColumnWidthStyleStrategy;
import com.litongjava.db.activerecord.Row;
import com.litongjava.kit.RowUtils;
import com.litongjava.table.convert.LocalDateTimeConverter;
import com.litongjava.table.convert.TimestampStringConverter;

/**
 * Excel 工具类
 *
 * @author litongjava
 */
public class EasyExcelUtils {

  /**
   * 将列表以 Excel 响应给前端
   *
   * @param response 响应
   * @param filename 文件名
   * @param sheetName Excel sheet 名
   * @param head Excel head 头
   * @param data 数据列表哦
   * @param  泛型,保证 head 和 data 类型的一致性
   * @throws IOException 写入失败的情况
   */
  public static  void write(OutputStream outputStream, String filename, String sheetName, Class head,
      List data) throws IOException {
    // 输出 Excel
    if (head != null) {
      getExcelWriteBuilder(outputStream)
          // 写入数据到sheet
          .sheet(sheetName).head(head).doWrite(data);
    } else {
      getExcelWriteBuilder(outputStream).sheet(sheetName).doWrite(data);
    }
  }

  public static void write(OutputStream outputStream, String sheetName, List records) {
    // 获取head
    String[] columnNames = null;
    int size = records.size();
    if (size > 0) {
      Row record = records.get(0);
      columnNames = record.getColumnNames();
    } else {
      return;
    }
    List> heads = head(columnNames);

    // 获取body
    List> columnValues = RowUtils.getListData(records, size);

    getExcelWriteBuilder(outputStream)
        //
        .sheet(sheetName)
        //
        .head(heads)
        //
        .doWrite(columnValues);

  }

  /**
   * 所有表格的数据
   * @param outputStream
   * @param allTableData
   */
  public static void write(OutputStream outputStream, Map> allTableData) {
    // 写入
    ExcelWriterBuilder excelWriterBuilder = getExcelWriteBuilder(outputStream);

    ExcelWriter excelWriter = excelWriterBuilder.build();

    Set sheetNames = allTableData.keySet();
    for (String sheetName : sheetNames) {
      List records = allTableData.get(sheetName);
      int listSize = records.size();
      // 获取head
      String[] columnNames = null;
      if (listSize > 0) {
        Row record = records.get(0);
        columnNames = record.getColumnNames();
      } else {
        continue;
      }
      List> heads = head(columnNames);

      List> columnValues = RowUtils.getListData(records, listSize);

      // 写入数据
      // excelWriterBuilder.sheet(sheetName).head(heads).doWrite(columnValues);
      // excelWriterBuilder.sheet().sheetName(sheetName).head(heads).doWrite(columnValues);
      // excelWriterBuilder.sheet().sheetName(sheetName).head(heads).doFill(columnValues);
      WriteSheet writeSheet = EasyExcel.writerSheet(sheetName).head(heads).build();
      excelWriter.write(columnValues, writeSheet);
    }
    excelWriter.finish();

  }

  private static ExcelWriterBuilder getExcelWriteBuilder(OutputStream outputStream) {
    ExcelWriterBuilder excelWriterBuilder = EasyExcel.write(outputStream)
        // 不要自动关闭,交给 Servlet 自己处理
        .autoCloseStream(false)
        // 基于 column 长度,自动适配。最大 255 宽度
        .registerWriteHandler(new LongestMatchColumnWidthStyleStrategy())
        // 日期格式转换
        .registerConverter(new LocalDateTimeConverter()).registerConverter(new TimestampStringConverter());
    return excelWriterBuilder;
  }

  public static List> head(String... heads) {
    // 写入表头
    List> list = new ArrayList<>();
    for (String headString : heads) {
      List head = new ArrayList<>();
      head.add(headString);
      list.add(head);
    }
    return list;
  }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy