CustomCellWriteWeightConfig.java 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. package com.ruoyi.common.utils.poi;
  2. import com.alibaba.excel.enums.CellDataTypeEnum;
  3. import com.alibaba.excel.metadata.Head;
  4. import com.alibaba.excel.metadata.data.CellData;
  5. import com.alibaba.excel.metadata.data.WriteCellData;
  6. import com.alibaba.excel.write.metadata.holder.WriteSheetHolder;
  7. import com.alibaba.excel.write.style.column.AbstractColumnWidthStyleStrategy;
  8. import org.apache.commons.collections.CollectionUtils;
  9. import org.apache.poi.ss.usermodel.Cell;
  10. import org.apache.poi.ss.usermodel.Sheet;
  11. import java.util.HashMap;
  12. import java.util.List;
  13. import java.util.Map;
  14. public class CustomCellWriteWeightConfig extends AbstractColumnWidthStyleStrategy {
  15. private Map<Integer, Map<Integer, Integer>> CACHE = new HashMap<>();
  16. @Override
  17. protected void setColumnWidth(WriteSheetHolder writeSheetHolder, List<WriteCellData<?>> cellDataList, Cell cell, Head head, Integer integer, Boolean isHead) {
  18. boolean needSetWidth = isHead || !CollectionUtils.isEmpty(cellDataList);
  19. if (needSetWidth) {
  20. Map<Integer, Integer> maxColumnWidthMap = CACHE.get(writeSheetHolder.getSheetNo());
  21. if (maxColumnWidthMap == null) {
  22. maxColumnWidthMap = new HashMap<>();
  23. CACHE.put(writeSheetHolder.getSheetNo(), maxColumnWidthMap);
  24. }
  25. Integer columnWidth = this.dataLength(cellDataList, cell, isHead);
  26. if (columnWidth >= 0) {
  27. if (columnWidth > 254) {
  28. columnWidth = 254;
  29. }
  30. Integer maxColumnWidth = maxColumnWidthMap.get(cell.getColumnIndex());
  31. if (maxColumnWidth == null || columnWidth > maxColumnWidth) {
  32. maxColumnWidthMap.put(cell.getColumnIndex(), columnWidth);
  33. Sheet sheet = writeSheetHolder.getSheet();
  34. sheet.setColumnWidth(cell.getColumnIndex(), columnWidth * 256);
  35. }
  36. }
  37. }
  38. }
  39. /**
  40. * 计算长度
  41. * @param cellDataList
  42. * @param cell
  43. * @param isHead
  44. * @return
  45. */
  46. private Integer dataLength(List<WriteCellData<?>> cellDataList, Cell cell, Boolean isHead) {
  47. if (isHead) {
  48. return cell.getStringCellValue().getBytes().length;
  49. } else {
  50. CellData cellData = cellDataList.get(0);
  51. CellDataTypeEnum type = cellData.getType();
  52. if (type == null) {
  53. return -1;
  54. } else {
  55. switch (type) {
  56. case STRING:
  57. // 换行符(数据需要提前解析好)
  58. int index = cellData.getStringValue().indexOf("\n");
  59. return index != -1 ?
  60. cellData.getStringValue().substring(0, index).getBytes().length + 1 : cellData.getStringValue().getBytes().length + 1;
  61. case BOOLEAN:
  62. return cellData.getBooleanValue().toString().getBytes().length;
  63. case NUMBER:
  64. return cellData.getNumberValue().toString().getBytes().length;
  65. default:
  66. return -1;
  67. }
  68. }
  69. }
  70. }
  71. }