首页
Web开发
Windows程序
编程语言
数据库
移动开发
系统相关
微信
其他好文
会员
首页
>
编程语言
> 详细
SpringMVC导出Excel
时间:
2015-06-12 17:26:03
阅读:
139
评论:
0
收藏:
0
[点我收藏+]
标签:
jave
excel导出
import java.math.BigDecimal;
import java.net.URLEncoder;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.List;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.lang3.StringUtils;
import org.apache.log4j.Logger;
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;
import org.apache.poi.hssf.util.HSSFColor;
import org.springframework.web.servlet.view.document.AbstractExcelView;
import com.afmobi.util.CommonUtil;
/**
*
* @author Administrator
*
*/
public class ExcelView extends AbstractExcelView {
public static final Logger _log = Logger.getLogger(ExcelView.class);
@Override
protected void buildExcelDocument(Map<String, Object> map, HSSFWorkbook workbook, HttpServletRequest req,
HttpServletResponse resp) throws Exception {
@SuppressWarnings("unchecked")
List<Map<String,Object>> rows=(List<Map<String, Object>>) map.get("rows");
String title = (String)map.get("title");
String[] h1=(String[])map.get("h1");
String[] h2=(String[])map.get("h2");
String excelName=title+".xls";
resp.setContentType("APPLICATION/OCTET-STREAM");
resp.setHeader("Content-Disposition", "attachment; filename="+ URLEncoder.encode(excelName, "UTF-8"));
HSSFSheet sheet = workbook.createSheet(title);
// 设置表格默认列宽度为15字节
sheet.setDefaultColumnWidth(25);
// 生成一个样式
HSSFCellStyle style = workbook.createCellStyle();
// 设置这些样式
style.setFillForegroundColor(HSSFColor.SKY_BLUE.index);
//设置表格背景色
style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
style.setBorderBottom(HSSFCellStyle.BORDER_THIN);
style.setBorderLeft(HSSFCellStyle.BORDER_THIN);
style.setBorderRight(HSSFCellStyle.BORDER_THIN);
style.setBorderTop(HSSFCellStyle.BORDER_THIN);
style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
// 生成一个字体
HSSFFont font = workbook.createFont();
font.setColor(HSSFColor.VIOLET.index);
font.setFontHeightInPoints((short) 12);
font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
// 把字体应用到当前样式
style.setFont(font);
// 设置另外一个样式
HSSFCellStyle style2 = workbook.createCellStyle();
style2.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
style2.setBorderBottom(HSSFCellStyle.BORDER_THIN);
style2.setBorderLeft(HSSFCellStyle.BORDER_THIN);
style2.setBorderRight(HSSFCellStyle.BORDER_THIN);
style2.setBorderTop(HSSFCellStyle.BORDER_THIN);
style2.setAlignment(HSSFCellStyle.ALIGN_CENTER);
style2.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
// 生成另一个字体
HSSFFont font2 = workbook.createFont();
//font2.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD); // 设置粗体
style2.setFont(font2);
HSSFRow header1 = sheet.createRow(0);
for(int i=0;i<h1.length;i++){
HSSFCell cell = header1.createCell(i);
cell.setCellStyle(style);
cell.setCellValue(h2[i]);
}
if(rows!=null){
for(int i=0;i<rows.size();i++){
HSSFRow row=sheet.createRow(i+1);
Map<String,Object> content=rows.get(i);
for(int j=0;j<h1.length;j++){
HSSFCell cell = row.createCell(j);
cell.setCellStyle(style2);
String key=h1[j];
Object c=content.get(key);
try{
if(c instanceof Integer || c instanceof BigDecimal){
if("status".equals(key)){
if((int)c == 1){
cell.setCellValue("Uploaded");
}else {
cell.setCellValue("Pending");
}
}else {
cell.setCellValue(c+"");
}
}else if(c instanceof Date){
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
cell.setCellValue(sdf.format(c));
} else{
if("countryCode".equals(key)){
String countryCode = (String) c;
String countryName = CommonUtil.getProperty(countryCode);
if(StringUtils.isNotEmpty(countryName)){
cell.setCellValue(countryName);
}else {
cell.setCellValue(countryCode);
}
}else {
cell.setCellValue((String)c);
}
}
}catch(Exception e){
_log.info(e.getMessage());
}
}
}
}
}
}
SpringMVC导出Excel
标签:
jave
excel导出
原文地址:http://blog.csdn.net/yj_vs_gy/article/details/46471755
踩
(
0
)
赞
(
0
)
举报
评论
一句话评论(
0
)
登录后才能评论!
分享档案
更多>
2021年07月29日 (22)
2021年07月28日 (40)
2021年07月27日 (32)
2021年07月26日 (79)
2021年07月23日 (29)
2021年07月22日 (30)
2021年07月21日 (42)
2021年07月20日 (16)
2021年07月19日 (90)
2021年07月16日 (35)
周排行
更多
Spring Cloud 从入门到精通(一)Nacos 服务中心初探
2021-07-29
基础的排序算法
2021-07-29
SpringBoot|常用配置介绍
2021-07-29
关于 .NET 与 JAVA 在 JIT 编译上的一些差异
2021-07-29
C语言常用函数-toupper()将字符转换为大写英文字母函数
2021-07-29
《手把手教你》系列技巧篇(十)-java+ selenium自动化测试-元素定位大法之By class name(详细教程)
2021-07-28
4-1 YAML配置文件 注入 JavaBean中
2021-07-28
【python】 用来将对象持久化的 pickle 模块
2021-07-28
马拉车算法
2021-07-28
用Python进行冒泡排序
2021-07-28
友情链接
兰亭集智
国之画
百度统计
站长统计
阿里云
chrome插件
新版天听网
关于我们
-
联系我们
-
留言反馈
© 2014
mamicode.com
版权所有 联系我们:gaon5@hotmail.com
迷上了代码!