java导出excel文件名乱码_Poi生成excel文件名乱码问题的解决方案

Poi是不错的java操作excel的包,开发过程中遇到生成excel文件名乱码、sheet表名乱码的问题,在这里我给大家一个完整的解决方案。

首先我们要写一个生成excel的模板。新建如下servlet:

import java.io.OutputStream;

import java.util.List;

import javax.servlet.http.HttpServletResponse;

import org.apache.poi.hssf.usermodel.HSSFCell;

import org.apache.poi.hssf.usermodel.HSSFCellStyle;

import org.apache.poi.hssf.usermodel.HSSFFont;

import org.apache.poi.hssf.usermodel.HSSFRow;

import org.apache.poi.hssf.usermodel.HSSFSheet;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;

public class ExcelAction

{

public static void excel(HttpServletResponse

response, List list,

String[] firstLine, String sheetName, String fileName) {

String[] array1 = null;

try {

short i

= 0;// row行标

response.setContentType("application/vnd.ms-excel");//设置生成的文件类型

response.setHeader("Content-Disposition", "filename="

+ new String(fileName.getBytes("gb2312"),

"iso8859-1"));//设置文件头编码方式和文件名

HSSFWorkbook wb = new HSSFWorkbook();//excel文件,一个excel文件包含多个表

HSSFSheet sheet = wb.createSheet();//表,一个表包含多个行

wb.setSheetName(0, sheetName, HSSFWorkbook.ENCODING_UTF_16);//

设置sheet中文编码;

//设置字体等样式

HSSFFont font = wb.createFont();

font.setFontHeightInPoints((short)

12);

font.setFontName("Courier New");

HSSFCellStyle style = wb.createCellStyle();

style.setFont(font);

style.setWrapText(true);

style.setAlignment(HSSFCellStyle.ALIGN_LEFT);

style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);

HSSFRow row;//行,一行包括多个单元格

HSSFCell cell;//单元格

row = sheet.createRow(i);//由HSSFSheet生成行

row.setHeightInPoints((float)

30);

//生成首行

for (short j

= 0; j < firstLine.length; j++) {

cell = row.createCell(j);//由行生成单元格

cell.setCellStyle(style);

cell.setEncoding(HSSFCell.ENCODING_UTF_16);//

设置cell中文编码;

cell.setCellValue(firstLine[j]);

sheet.setColumnWidth(j, (short)

(5000));

}

//生成所有行的单元格内容,如果测试list设为null即可,或者将这一段代码注释掉

if (null ==

list || list.size() == 0) {

// do nothing

} else {

for (int k

= 0; k < list.size(); k++) {

row = sheet.createRow(++i);

row.setHeightInPoints((float)

33);

array1 = (String[]) list.get(k);

if (null !=

array1 && array1.length != 0) {

for (int f

= 0; f < array1.length; f++) {

cell = row.createCell((short)

f);

cell.setCellStyle(style);

cell.setEncoding(HSSFCell.ENCODING_UTF_16);

cell.setCellValue(array1[f]);

}

}

}

}

//输出

OutputStream out = response.getOutputStream();

wb.write(out);

out.close();

} catch (Exception

ex) {

ex.printStackTrace();

}

return;

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java导出Excel文件名出现乱码问题可以通过设置`Content-disposition`的header来解决。其中,使用`URLEncoder.encode`方法将文件名进行编码,再将编码后的文件名设置到header中。例如,在SSM框架下可以这样处理:所示的`exportXls`方法。这个方法使用了AutoPoi库来导出Excel文件,并且可以设置导出文件名和其他参数。 总结来说,要解决Java导出Excel文件名乱码问题,可以根据浏览器类型选择适合的文件名编码方式,或者使用工具类来简化导出操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [java项目poi插件导出Excel文件名中文乱码](https://blog.csdn.net/weixin_42129270/article/details/121425098)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [Java导出Excel表格文件名乱码问题](https://blog.csdn.net/m0_49790240/article/details/127434593)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值