Strust2+POI导出exel表格且解决文件名中文乱码/不显示
下载并导入项目【poi.3.17.jar】
strust.xml
<action name="returnLate_*" class="com.stureturnlate.moudels.biz.action.return_late.ReturnLateAction" method="{1}">
<result name="list">/page/moudels/biz/return_late/returnLateList.jsp</result>
<result name="openAdd">/page/moudels/biz/return_late/returnLateAdd.jsp</result>
<!--<result name="openEdit">/page/biz/student/studentUpdate.jsp</result>-->
<result name="openDetails">/page/moudels/biz/return_late/returnLateDetails.jsp</result> <!-- 导出Excel -->
<result name="download" type="stream">
<param name="contentType">application/vnd.ms-excel</param><!-- 注意这里的ContentType -->
<param name="contentDisposition">attachment;filename="${fileName}.xls"</param><!-- 下载文件的名字 -->
<param name="bufferSize"></param><!-- 下载文件的大小 =1M -->
<param name="inputName">excelFile</param><!-- 这里需要和Action里的变量名一致 -->
</result>
</action>ReturnLateAction.class
/**
* 导出
* @return
*/
public String download() throws Exception { List<ReturnLateEntity> returnLateEntityList = new ArrayList<>();
fileName = fileName+ DateTool.dateFormat(new Date());
fileName=new String(fileName.getBytes("gb2312"), "iso8859-1");//防止中文乱码或不显示
//TODO 第一步:声明excel的文档对象
HSSFWorkbook returnLateExcel;
try {
//查询的结果,插入Excel填充数据
String[] ids = returnLateIds.split(",");
returnLateEntityList = returnLateService.selectAllReturnLate(ids); //TODO 第二步:获取excel的文档对象
returnLateExcel = CreateExcel.createReturnLateExcel(returnLateEntityList); ByteArrayOutputStream output = new ByteArrayOutputStream();//字节数组输出流 //TODO 第三步:写入字节数组输出流
returnLateExcel.write(output);
byte[] ba = output.toByteArray(); //TODO 第四步:为输入流对象赋值
excelFile = new ByteArrayInputStream(ba); output.flush();
output.close();//关闭
} catch (SQLException e) {
System.out.println("晚归记录文件内容写入或者创建失败失败!");
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} return "download";
}文件导出类CreateExcel.class
package com.stureturnlate.common; import com.stureturnlate.moudels.vo.*;
import org.apache.poi.hssf.usermodel.*;
import org.apache.poi.ss.usermodel.HorizontalAlignment; import java.sql.SQLException;
import java.util.List; /**
* @author soldier
* @title: CreateExcel
* @projectName stu_return_late
* @description: 文件导出Excel
* @date 19-6-10下午9:56
*/
public class CreateExcel { public static HSSFWorkbook createReturnLateExcel(List<ReturnLateEntity> returnLateEntityList) throws SQLException {
// 创建一个Excel文件
HSSFWorkbook workbook = new HSSFWorkbook();//excel的文档对象
// 创建一个工作表
HSSFSheet sheet = workbook.createSheet("学生晚归记录");
// 添加表头行
HSSFRow hssfRow = sheet.createRow(0);
// 设置单元格格式居中
HSSFCellStyle cellStyle = workbook.createCellStyle();
cellStyle.setAlignment(HorizontalAlignment.CENTER); int index = 0;
// 添加表头内容
HSSFCell headCell = hssfRow.createCell(index++);
headCell.setCellValue("晚归编号");
headCell.setCellStyle(cellStyle); headCell = hssfRow.createCell(index++);
headCell.setCellValue("晚归学生");
headCell.setCellStyle(cellStyle); headCell = hssfRow.createCell(index++);
headCell.setCellValue("所属学院");
headCell.setCellStyle(cellStyle); headCell = hssfRow.createCell(index++);
headCell.setCellValue("学生所在宿舍");
headCell.setCellStyle(cellStyle); headCell = hssfRow.createCell(index++);
headCell.setCellValue("晚归时间");
headCell.setCellStyle(cellStyle); headCell = hssfRow.createCell(index++);
headCell.setCellValue("晚归原因");
headCell.setCellStyle(cellStyle); headCell = hssfRow.createCell(index++);
headCell.setCellValue("记录者工号");
headCell.setCellStyle(cellStyle); headCell = hssfRow.createCell(index);
headCell.setCellValue("记录者姓名");
headCell.setCellStyle(cellStyle); // 添加数据内容
for (int i = 0; i < returnLateEntityList.size(); i++) {
hssfRow = sheet.createRow((int) i + 1);
ReturnLateEntity returnLateEntity = returnLateEntityList.get(i); index = 0;
// 创建单元格,并设置值
HSSFCell cell = hssfRow.createCell(index++);
cell.setCellValue(returnLateEntity.getReturnLateId());
cell.setCellStyle(cellStyle); cell = hssfRow.createCell(index++);
StudentEntity studentEntity = new StudentEntity();//获取学生名称
cell.setCellValue(studentEntity.getStudentName());
cell.setCellStyle(cellStyle); cell = hssfRow.createCell(index++);
CollegeEntity collegeEntity = new CollegeEntity();//获取学院
cell.setCellValue(collegeEntity.getCollegeName());
cell.setCellStyle(cellStyle); cell = hssfRow.createCell(index++);
HostelEntity hostelEntity = new HostelEntity();//获取宿舍名称
cell.setCellValue(hostelEntity.getHostelName());
cell.setCellStyle(cellStyle); cell = hssfRow.createCell(index++);
cell.setCellValue(DateTool.dateTimeFormat(returnLateEntity.getReturnLateTime()));
cell.setCellStyle(cellStyle); cell = hssfRow.createCell(index++);
cell.setCellValue(returnLateEntity.getReturnLateCause());
cell.setCellStyle(cellStyle); cell = hssfRow.createCell(index++);
DormMasterEntity dormMasterEntity = new DormMasterEntity();
cell.setCellValue(dormMasterEntity.getDormMasterId());
cell.setCellStyle(cellStyle); cell = hssfRow.createCell(index);
cell.setCellValue(dormMasterEntity.getDormMasterName());
cell.setCellStyle(cellStyle);
} try {
return workbook; } catch (Exception e) {
e.printStackTrace();
}
return null;
}
}
Strust2+POI导出exel表格且解决文件名中文乱码/不显示的更多相关文章
- windows10下面部署nginx(解决文件名中文乱码问题)
由于开发需要,我们总是需要先在windows环境下面部署项目进行测试,通过之后才会移植到linux系统进行测试部署. 本篇文章会介绍一下windows终端下面部署nginx WEB服务的一些步骤流程, ...
- 解决swfupload上传控件文件名中文乱码问题 三种方法 flash及最新版本11.8.800.168
目前比较流行的是使用SWFUpload控件,这个控件的详细介绍可以参见官网http://demo.swfupload.org/v220/index.htm 在使用这个控件批量上传文件时发现中文文件名都 ...
- poi导出word表格详解 超详细了
转:非常感谢原作者 poi导出word表格详解 2018年07月20日 10:41:33 Z丶royAl 阅读数:36138 一.效果如下 二.js代码 function export_word( ...
- Maven项目结合POI导出Excl表格Demo-亲测可用
Maven项目结合POI导出Excl表格 一.POM文件添加依赖 <!-- https://mvnrepository.com/artifact/org.apache.poi/poi --> ...
- PHP Header下载文件在IE文件名中文乱码问题
解决PHP Header下载文件在IE文件名中文乱码有两种常见的,一种是是把页面编码改成utf8,另一种是对中文url进入urlencode编码,根据UA检测,区别下载,就可以解决了 $filenam ...
- Linux->Windows主机目录和文件名中文乱码恢复
目录 Linux->Windows主机目录和文件名中文乱码恢复 声明 一. 乱码问题 二. 调试环境 三. 目录和文件名乱码恢复 3.1 可选方案 3.1.1 通过合适的编解码转换 3.1.2 ...
- 彻底解决matplotlib中文乱码问题(转)
彻底解决matplotlib中文乱码问题 1.环境查看a.系统版本查看[hadoop@p168 ~]$ cat /etc/redhat-releaseCentOS Linux release 7.2. ...
- Centos7 unzip文件名中文乱码
Centos7 unzip文件名中文乱码 前言 今天在批量处理windos文件时为了方便操作,将windos下面的文件夹打成zip包上传至centos7中解压处理,发现解压后中文文件名变成了乱码,如下 ...
- 解决Eclipse中文乱码 - 技术博客 - 51CTO技术博客 http://hsj69106.blog.51cto.com/1017401/595598/
解决Eclipse中文乱码 - 技术博客 - 51CTO技术博客 http://hsj69106.blog.51cto.com/1017401/595598/
随机推荐
- tf.stack( )和tf.unstack( )
相同点:他们都增加了矩阵的维度,而split()不改变维度! tf.stack()这是一个矩阵拼接的函数,tf.unstack()则是一个矩阵分解的函数 c是拼接,而d和e则是不同维度的分解
- 对js库的调研研究------引用
1. 引言 从以下几个方面来阐述这个问题: 特性. 稳定性. 性能. 包生态. 社区. 学习曲线. 文档. 工具. 发展历史. 团队. 兼容性. 趋势. 2.概述 & 精读 特性 当你调研一个 ...
- SpringBoot 1.X版本设置Https访问以及跨域https访问的问题
最近在做的一个项目中出现了Https域向非Https域发送ajax请求无法通过的问题 Mixed Content: The page at was loaded over HTTPS, but req ...
- AOP 相关包
aop 命名空间,jar 扫路径
- Java课堂动手动脑
1.使用Files. walkFileTree()找出指定文件夹下所有大于指定大小(比如1M)的文件: 代码: package test; import java.io.IOException; im ...
- Android中StatFs获取系统/sdcard存储(剩余空间)大小
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 3 ...
- Vuex入门(转)
参考:https://segmentfault.com/a/1190000015782272 https://www.cnblogs.com/y896926473/p/6709733.html 如果你 ...
- http三次握手,四次挥手
本文经过借鉴书籍资料.他人博客总结出的知识点,欢迎提问 序列号seq:占4个字节,用来标记数据段的顺序,TCP把连接中发送的所有数据字节都编上一个序号,第一个字节的编号由本地随机产生:给字节编上序号后 ...
- js 放回上一页
window.history.go(-1);//返回上一页不刷新 window.location.href = document.referrer;//返回上一页并刷新
- django项目部署过程
django项目部署过程 1.上传代码 用git或者其他工具,如scp 代码上传后保证每个应用下的migrations文件夹里只有一个__init__.py文件,自己的迁移文件不要上传上来,具体的gi ...