java导出 Excel时,对特殊字符编码后的字符串进行解码
大致情况描述为:我从页面input输入了a×b通过post方式提交到后台,后台收到的内容为a×b然后将a×b保存到了数据库此时查询出来显示在页面为...
大致情况描述为:
我从页面input输入了a×b
通过post方式提交到后台,后台收到的内容为 a×b
然后将 a×b 保存到了数据库
此时查询出来显示在页面为a×b (显示没问题,自动转码了)
但是,我在将数据库数据导出到excel时,还是原版导出了a×b
有没有什么处理可以在导出时将其转码成a×b?
备注:页面很多,字段也很多,挨个针对性修改不现实。所以我的想法时能不能在导出数据时解决?
导出excel的部分代码为
//调用导出方法
XSSFWorkbook wb = ExcelPoiUtils.exportExcel(dataList, map);
String catNames = getNameByCatalogId(catalog);
String fileName = new String(catNames.getBytes("UTF-8"),"iso8859-1");
OutputStream output = response.getOutputStream();
response.reset();
response.setHeader("Content-disposition", "attachment; filename="+fileName+".xlsx");
System.out.println(getNameByCatalogId(catalog));
response.setContentType("application/msexcel");
wb.write(output);
output.close();
或者有没有其他更好的解决方法,最终结果只要输入什么,就显示、导出什么就行。
...这个页面也给我编码了...我加(隔开)修改一下
大致情况描述为:
我从页面input输入了a×b
通过post方式提交到后台,后台收到的内容为 a&ti(隔开)mes;b
然后将 a&ti(隔开)mes;b 保存到了数据库
此时查询出来显示在页面为a×b (显示没问题,自动转码了)
但是,我在将数据库数据导出到excel时,还是原版导出了a&ti(隔开)mes;b
有没有什么处理可以在导出时将其转码成a×b?
问题解决了,在导出excel写入每个数据时,用StringEscapeUtils.unescapeHtml3( "需要反转义的任何内容");
就是cell.setCellValue(StringEscapeUtils.unescapeHtml3(value + ""));
当然,每跳都要反转义一次,程序会慢一点点,测试结果只是慢了5%左右,在接受范围内。
来个人拿分吧 展开
我从页面input输入了a×b
通过post方式提交到后台,后台收到的内容为 a×b
然后将 a×b 保存到了数据库
此时查询出来显示在页面为a×b (显示没问题,自动转码了)
但是,我在将数据库数据导出到excel时,还是原版导出了a×b
有没有什么处理可以在导出时将其转码成a×b?
备注:页面很多,字段也很多,挨个针对性修改不现实。所以我的想法时能不能在导出数据时解决?
导出excel的部分代码为
//调用导出方法
XSSFWorkbook wb = ExcelPoiUtils.exportExcel(dataList, map);
String catNames = getNameByCatalogId(catalog);
String fileName = new String(catNames.getBytes("UTF-8"),"iso8859-1");
OutputStream output = response.getOutputStream();
response.reset();
response.setHeader("Content-disposition", "attachment; filename="+fileName+".xlsx");
System.out.println(getNameByCatalogId(catalog));
response.setContentType("application/msexcel");
wb.write(output);
output.close();
或者有没有其他更好的解决方法,最终结果只要输入什么,就显示、导出什么就行。
...这个页面也给我编码了...我加(隔开)修改一下
大致情况描述为:
我从页面input输入了a×b
通过post方式提交到后台,后台收到的内容为 a&ti(隔开)mes;b
然后将 a&ti(隔开)mes;b 保存到了数据库
此时查询出来显示在页面为a×b (显示没问题,自动转码了)
但是,我在将数据库数据导出到excel时,还是原版导出了a&ti(隔开)mes;b
有没有什么处理可以在导出时将其转码成a×b?
问题解决了,在导出excel写入每个数据时,用StringEscapeUtils.unescapeHtml3( "需要反转义的任何内容");
就是cell.setCellValue(StringEscapeUtils.unescapeHtml3(value + ""));
当然,每跳都要反转义一次,程序会慢一点点,测试结果只是慢了5%左右,在接受范围内。
来个人拿分吧 展开
1个回答
展开全部
//关键代码
HSSFCell cell = new HSSFCell();
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
HSSFCell cell = new HSSFCell();
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询