easyexcel The maximum length of cell contents (text) is 32,767 characters

使用easyexcel向excel中写内容出现了单元格大小不能超过32,767的限制,这是因为excel 2007限制单个cell不能超过32767个字符,但是现在都2020年了。。。。

 .xls和.xlsx文件格式有32,767个字符的硬限制. Apache POI只是强制执行Excel限制的文件格式.您可以在Microsoft文档中查看这些限制的详细信息,也可以在 this Apache POI javadoc page中很好地捕获

将poi更新到最新版本仔细看看源码 org.apache.poi.ss.SpreadsheetVersion 中只用excel97 和excel2007俩个选项 ,XSSFCell 类被修饰为final 不能被继承重写版本校验方法。
 
解决办法:
方法一:扩大最大值

在自己的项目文件夹下创建org.apache.poi.ss.SpreadsheetVersion 类,复制poi中的该类源码,excel2007中的最后一个值改为int类型最大值。重试导出问题解决。

方法二:截取,分成多列存储

 1 private static void writeRowsToExcel(XSSFWorkbook wb, Sheet sheet, List<List<Object>> rows, int rowIndex) {
2 int colIndex = 0;
3
4 Font dataFont = wb.createFont();
5 dataFont.setFontName("simsun");
6 dataFont.setColor(IndexedColors.BLACK.index);
7
8 XSSFCellStyle dataStyle = wb.createCellStyle();
9 dataStyle.setAlignment(XSSFCellStyle.ALIGN_CENTER);
10 dataStyle.setVerticalAlignment(XSSFCellStyle.VERTICAL_CENTER);
11 dataStyle.setFont(dataFont);
12 setBorder(dataStyle, BorderStyle.THIN, new XSSFColor(new Color(0, 0, 0)));
13
14 for (List<Object> rowData : rows) {
15 Row dataRow = sheet.createRow(rowIndex);
16 colIndex = 0;
17 for (Object cellData : rowData) {
18 colIndex = setCell(cellData.toString(), dataRow, colIndex, dataStyle);
19 }
20 rowIndex++;
21 }
22 }
23
24 private static int setCell(String data, Row dataRow, Integer colIndex, XSSFCellStyle dataStyle) {
25
26 int max = 32767;
27 if (data == null || data.length() < max) {
28 Cell cell = dataRow.createCell(colIndex);
29 cell.setCellStyle(dataStyle);
30 cell.setCellValue(data == null ? "" : data);
31 colIndex++;
32 } else {
33 int num = data.length() / max;
34 for (int i = 0; i < num; i++) {
35 Cell cell = dataRow.createCell(colIndex);
36 cell.setCellStyle(dataStyle);
37 cell.setCellValue(data.substring(i * max, max * (i + 1)));
38 colIndex++;
39 }
40 int extra = data.length() % max;
41 if (extra > 0) {
42 Cell cell = dataRow.createCell(colIndex);
43 cell.setCellStyle(dataStyle);
44 cell.setCellValue(data.substring(num * max, num * max + extra));
45 colIndex++;
46 }
47 }
48 return colIndex;
49 }

示例

方法三:切换文件格式 (推荐)

如果您确实需要长文本,则需要切换到另一种文件格式,例如CSV

CSV是逗号分隔文件(Comma Separated Values)的首字母英文缩写,是一种用来存储数据的纯文本格式,通常用于电子表格或数据库软件。在 CSV文件中,数据“栏”以逗号分隔,可允许程序通过读取文件为数据重新创建正确的栏结构,并在每次遇到逗号时开始新的一栏。如:

1,张三,男

2,李四,男
3,小红,女

  1 package com.yph.omp.common.util;
2
3 import java.io.BufferedWriter;
4 import java.io.File;
5 import java.io.FileInputStream;
6 import java.io.FileNotFoundException;
7 import java.io.FileOutputStream;
8 import java.io.IOException;
9 import java.io.InputStream;
10 import java.io.OutputStream;
11 import java.io.OutputStreamWriter;
12 import java.util.ArrayList;
13 import java.util.Iterator;
14 import java.util.LinkedHashMap;
15 import java.util.List;
16 import java.util.Map;
17
18 import javax.servlet.http.HttpServletRequest;
19 import javax.servlet.http.HttpServletResponse;
20
21 import org.apache.commons.beanutils.BeanUtils;
22 import org.junit.Test;
23
24 /**
25 * Java生成CSV文件
26 */
27 public class CSVUtil {
28
29 /**
30 * 生成为CVS文件
31 *
32 * @param exportData
33 * 源数据List
34 * @param map
35 * csv文件的列表头map
36 * @param outPutPath
37 * 文件路径
38 * @param fileName
39 * 文件名称
40 * @return
41 */
42 @SuppressWarnings("rawtypes")
43 public static File createCSVFile(List exportData, LinkedHashMap map,
44 String outPutPath, String fileName) {
45 File csvFile = null;
46 BufferedWriter csvFileOutputStream = null;
47 try {
48 File file = new File(outPutPath);
49 if (!file.exists()) {
50 file.mkdir();
51 }
52 // 定义文件名格式并创建
53 csvFile = File.createTempFile(fileName, ".csv",
54 new File(outPutPath));
55 // UTF-8使正确读取分隔符","
56 csvFileOutputStream = new BufferedWriter(new OutputStreamWriter(
57 new FileOutputStream(csvFile), "GBK"), 1024);
58 // 写入文件头部
59 for (Iterator propertyIterator = map.entrySet().iterator(); propertyIterator
60 .hasNext();) {
61 java.util.Map.Entry propertyEntry = (java.util.Map.Entry) propertyIterator
62 .next();
63 csvFileOutputStream
64 .write("\"" + (String) propertyEntry.getValue() != null ? (String) propertyEntry
65 .getValue() : "" + "\"");
66 if (propertyIterator.hasNext()) {
67 csvFileOutputStream.write(",");
68 }
69 }
70 csvFileOutputStream.newLine();
71 // 写入文件内容
72 for (Iterator iterator = exportData.iterator(); iterator.hasNext();) {
73 Object row = (Object) iterator.next();
74 for (Iterator propertyIterator = map.entrySet().iterator(); propertyIterator
75 .hasNext();) {
76 java.util.Map.Entry propertyEntry = (java.util.Map.Entry) propertyIterator
77 .next();            /*-------------------------------*/ 
78 //以下部分根据不同业务做出相应的更改
79 StringBuilder sbContext = new StringBuilder("");
80 if (null != BeanUtils.getProperty(row,(String) propertyEntry.getKey())) {
81 if("证件号码".equals(propertyEntry.getValue())){
82 //避免:身份证号码 ,读取时变换为科学记数 - 解决办法:加 \t(用Excel打开时,证件号码超过15位后会自动默认科学记数)
83 sbContext.append(BeanUtils.getProperty(row,(String) propertyEntry.getKey()) + "\t");
84 }else{
85 sbContext.append(BeanUtils.getProperty(row,(String) propertyEntry.getKey()));
86 }
87 }
88 csvFileOutputStream.write(sbContext.toString());
89             /*-------------------------------*/
90 if (propertyIterator.hasNext()) {
91 csvFileOutputStream.write(",");
92 }
93 }
94 if (iterator.hasNext()) {
95 csvFileOutputStream.newLine();
96 }
97 }
98 csvFileOutputStream.flush();
99 } catch (Exception e) {
100 e.printStackTrace();
101 } finally {
102 try {
103 csvFileOutputStream.close();
104 } catch (IOException e) {
105 e.printStackTrace();
106 }
107 }
108 return csvFile;
109 }
110
111 /**
112 * 下载文件
113 *
114 * @param response
115 * @param csvFilePath
116 * 文件路径
117 * @param fileName
118 * 文件名称
119 * @throws IOException
120 */
121 public static void exportFile(HttpServletRequest request,
122 HttpServletResponse response, String csvFilePath, String fileName)
123 throws IOException {
124 response.setCharacterEncoding("UTF-8");
125 response.setContentType("application/csv;charset=GBK");
126
127 response.setHeader("Content-Disposition", "attachment; filename="
128 + new String(fileName.getBytes("GB2312"), "ISO8859-1"));
129 InputStream in = null;
130 try {
131 in = new FileInputStream(csvFilePath);
132 int len = 0;
133 byte[] buffer = new byte[1024];
134 OutputStream out = response.getOutputStream();
135 while ((len = in.read(buffer)) > 0) {
136 out.write(buffer, 0, len);
137 }
138 } catch (FileNotFoundException e1) {
139 System.out.println(e1);
140 } finally {
141 if (in != null) {
142 try {
143 in.close();
144 } catch (Exception e1) {
145 throw new RuntimeException(e1);
146 }
147 }
148 }
149 }
150
151 /**
152 * 删除该目录filePath下的所有文件
153 *
154 * @param filePath
155 * 文件目录路径
156 */
157 public static void deleteFiles(String filePath) {
158 File file = new File(filePath);
159 if (file.exists()) {
160 File[] files = file.listFiles();
161 for (int i = 0; i < files.length; i++) {
162 if (files[i].isFile()) {
163 files[i].delete();
164 }
165 }
166 }
167 }
168
169 /**
170 * 删除单个文件
171 *
172 * @param filePath
173 * 文件目录路径
174 * @param fileName
175 * 文件名称
176 */
177 public static void deleteFile(String filePath, String fileName) {
178 File file = new File(filePath);
179 if (file.exists()) {
180 File[] files = file.listFiles();
181 for (int i = 0; i < files.length; i++) {
182 if (files[i].isFile()) {
183 if (files[i].getName().equals(fileName)) {
184 files[i].delete();
185 return;
186 }
187 }
188 }
189 }
190 }
191
192 @SuppressWarnings({ "unchecked", "rawtypes" })
193 @Test
194 public void createFileTest() {
195 List exportData = new ArrayList<Map>();
196 Map row1 = new LinkedHashMap<String, String>();
197 row1.put("1", "11");
198 row1.put("2", "12");
199 row1.put("3", "13");
200 row1.put("4", "14");
201 exportData.add(row1);
202 row1 = new LinkedHashMap<String, String>();
203 row1.put("1", "21");
204 row1.put("2", "22");
205 row1.put("3", "23");
206 row1.put("4", "24");
207 exportData.add(row1);
208 LinkedHashMap map = new LinkedHashMap();
209 map.put("1", "第一列");
210 map.put("2", "第二列");
211 map.put("3", "第三列");
212 map.put("4", "第四列");
213
214 String path = "d:/export";
215 String fileName = "文件导出";
216 File file = CSVUtil.createCSVFile(exportData, map, path, fileName);
217 String fileNameNew = file.getName();
218 String pathNew = file.getPath();
219 System.out.println("文件名称:" + fileNameNew );
220 System.out.println("文件路径:" + pathNew );
221 }
222 }//注:BeanUtils.getProperty(row,(String) propertyEntry.getKey()) + "\t" ,只为解决数字格式超过15位后,在Excel中打开展示科学记数问题。

Java生成CSV文件

参考:
https://www.jianshu.com/p/9e73399b6c38 
http://www.voidcn.com/article/p-wrsnsvtm-bxy.html
https://www.cnblogs.com/bailuobo/p/4911764.html

easyexcel: The maximum length of cell contents (text) is 32,767 characters的更多相关文章

  1. Maximum length of a table name in MySQL

    http://dev.mysql.com/doc/refman/5.7/en/identifiers.html The following table describes the maximum le ...

  2. The maximum number of cell styles was exceeded. You can define up to 4000 styles

    POI操作Excel中,导出的数据不是很大时,则不会有问题,而数据很多或者比较多时, 就会报以下的错误,是由于cell styles太多create造成,故一般可以把cellstyle设置放到循环外面 ...

  3. [LeetCode] Maximum Length of Repeated Subarray 最长的重复子数组

    Given two integer arrays A and B, return the maximum length of an subarray that appears in both arra ...

  4. [Swift]LeetCode718. 最长重复子数组 | Maximum Length of Repeated Subarray

    Given two integer arrays A and B, return the maximum length of an subarray that appears in both arra ...

  5. oracle 导入报错:field in data file exceeds maximum length

    今天用sqlldr导入数据时候报错: " Record 1: Rejected - Error on table ks_test, column khname.Field in data f ...

  6. [LeetCode]Maximum Length of Repeated Subarray

    Maximum Length of Repeated Subarray: Given two integer arrays A and B, return the maximum length of ...

  7. sqlldr Field in data file exceeds maximum length "

    使用sqlldr导数时出现如下错误: " Record 1: Rejected - Error on table PC_PLANNAME, column PLANNAME.Field in ...

  8. LeetCode Maximum Length of Pair Chain

    原题链接在这里:https://leetcode.com/problems/maximum-length-of-pair-chain/description/ 题目: You are given n  ...

  9. 【POI】导出xls文件报错:The maximum number of cell styles was exceeded. You can define up to 4000 styles in a .xls workbook

    使用POI导出xls文件,由于数据过多,导致导出xls报错如下: The maximum number of cell styles was exceeded. You can define up t ...

  10. FireDAC 出现Variable length column[*] overflow. Value length - [80], column maximum length

    FireDAC 出现Variable length column[*] overflow. Value length - [80], column maximum length FireDAC的 TF ...

随机推荐

  1. [转帖]2.2.1 Lightning 工作原理

    https://book.tidb.io/session2/chapter2/lightning-internal.html TiDB Lightning 工具支持高速导入 Mydumper 和 CS ...

  2. [转帖]Jmeter插件之ServerAgent服务器性能监控工具的安装和使用

    https://www.cnblogs.com/pachongshangdexuebi/p/13354201.html 一.前言    性能测试时我们关注的重要指标是:并发用户数,TPS,请求成功率, ...

  3. 【转帖】《MySQL高级篇》四、索引的存储结构

    1. 为什么使用索引 假如给数据使用 二叉树 这样的数据结构进行存储,如下图所示 2.索引及其优缺点 2.1 索引概述 2.2 优点 类似大学图书馆建书目索引,提高数据检索的效率,降低 数据库的 IO ...

  4. jconsole的简单学习

    摘要 jconsole 是JDK自带的一款图形化监测工具 他可以监测本地程序,也可以检测远程的机器 在没有其他监控手段可以使用的情况下可以快速进行必要的监测 使用方法也比较简单. 本地监控 jcons ...

  5. centos8上安装中文字符集

    https://www.cnblogs.com/kaishirenshi/p/12669353.html yum install glibc-common yum install -y langpac ...

  6. 如何将axios封装成一个插件

    01==>重新写axios的插件 在src下创建一个插件文件为plugins 在创建一个http.js文件 根据官方插件 重新写axios的插件 http.js文件如下 import axios ...

  7. 【小测试】VictoriaMetrics中如何汇总单个time series上的多个data point?

    作者:张富春(ahfuzhang),转载时请注明作者和引用链接,谢谢! cnblogs博客 zhihu Github 公众号:一本正经的瞎扯 问题最终在andy专家的帮助下解决,但是内部的原理还是很迷 ...

  8. vim 从嫌弃到依赖(12)——打开及保存文件

    在前几篇文章中,我们从vim各种模式的使用着手介绍了vim如何进行文本本身的编辑.也通过缓冲区列表的介绍了解到了vim是如何进行打开文件的管理.这篇我们将会着眼于文件的打开和保存的基本操作.通过这篇的 ...

  9. SqlSugar分页查询

    同步分页  int pagenumber= 1; // pagenumber是从1开始的不是从零开始的  int pageSize = 20;  int totalCount=0;  //单表分页   ...

  10. Mygin中间件优化及日志中间件

    本篇是mygin的第七篇,参照gin框架,感兴趣的可以从 Mygin第一篇 开始看,Mygin从零开始完全手写,在实现的同时,带你一窥gin框架的核心原理实现. 目的 中间件Middleware优化 ...