java用jxl导出数据超过3000就报错。。

org.apache.jasper.JasperException:java.lang.IllegalStateException:getOutputStream()ha... org.apache.jasper.JasperException: java.lang.IllegalStateException: getOutputStream() has already been called for this response 展开
 我来答
fanqiezz11
2014-11-19 · TA获得超过777个赞
知道小有建树答主
回答量:369
采纳率:0%
帮助的人:262万
展开全部
本人前阵子就是在解决这个问题,应该是jxl包的问题,我的解决方法是新写了一个方法,新方法不用jxl而用poi,可以一次导出3W以上的数据不出错,如果原来的方法不想去掉的话,本人是在写excel的时候先做记录条数判断,如果较大(>2000)则调用新类的新方法,基本问题已经解决,可供参考,要关键代码的话也可以提供。
追问
谢了。如果方便的话,把用poi写的方法发我一下。。
追答
public class BigDataTool {
public String writeToExcelForBigData(String filePath, List recordList,
String[] title) throws Exception {
File file = new File(filePath);
OutputStream outputStream =null;
try{
outputStream = new FileOutputStream(file);
}catch(Exception e ){
e.printStackTrace();
}

HSSFWorkbook workbook = new HSSFWorkbook();
HSSFSheet sheet = workbook.createSheet("sheet1");

//标题行
HSSFRow rowHead = sheet.createRow(0);
for(int i=0;i<title.length;i++){
HSSFCell cell = rowHead.createCell((short)i);
cell.setCellValue(title[i]);
}

//从第二行写记录
for(int rownum=1;rownum<=recordList.size();rownum++){
HSSFRow row = sheet.createRow(rownum);
Element attr = (Element)recordList.get(rownum-1);
List list = attr.getChildren();
for(int colnum = 0;colnum<list.size();colnum++){
Element item = (Element)list.get(colnum);
HSSFCell cell = row.createCell((short)colnum);
cell.setCellValue(new HSSFRichTextString(item.getText()));
}
}
workbook.write(outputStream);
return filePath;
}
}
通过传参的方式将文件路径、表头、记录传过来。字数限制,删掉了一些格式!
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式