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的更多相关文章

  1. springmvc 导出excel

    1.pom.xml <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www ...

  2. Springmvc导出Excel(maven)

    一.导入依赖 <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</ar ...

  3. springmvc导出excel(POI)

    /** * 导出excel表格 */ @RequestMapping(value = "/doExportData", method = {RequestMethod.POST, ...

  4. springmvc导出excel并弹出下载框

    https://my.oschina.net/aptx4869/blog/298507

  5. springMVC框架+POI组件导出Excel

    目的:访问url(http://localhost:8080/POIOutputExcel/outputexcel.do)实现excel导出,效果图如下: 文件目录(配置文件就不多说了,跟前面的随笔一 ...

  6. 关于EasyPoi导出Excel

    如果你觉得Easypoi不好用,喜欢用传统的poi,可以参考我的这篇博客:Springmvc导出Excel(maven) 当然了,万变不离其宗.Easypoi的底层原理还是poi.正如MyBatis ...

  7. 用SpringMvc实现Excel导出功能

    以前只知道用poi导出Excel,最近用了SpringMvc的Excel导出功能,结合jxl和poi实现,的确比只用Poi好,两种实现方式如下: 一.结合jxl实现: 1.引入jxl的所需jar包: ...

  8. SpringMvc 使用poi导入导出Excel

    Util类 package com.common.util; public class ExportUtil { private XSSFWorkbook wb = null; private XSS ...

  9. springMVC中使用POI方式导出excel至客户端、服务器实例

    Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式档案读和写的功能. 这里的方法支持导出excel至项目所在服务器,或导 ...

随机推荐

  1. 卸载钩子 UnhookWindowsHookEx

    The UnhookWindowsHookEx function removes a hook procedure installed in a hook chain by the SetWindow ...

  2. win7 命令行禁用开启usb存储

    禁用: reg add "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\usbstor" /v Start /t reg ...

  3. flask中模板日期格式控制和jinja2中模板格式控制

    1.flask的模块语言采用的是jinja2,首先说一下jinja2中的模板格式控制的使用,即模板自定义filters的使用. python的脚本如下(采用的是格式显示日期): 1 from jinj ...

  4. PHP 下基于 php-amqp 扩展的 RabbitMQ 简单用例 (四) -- Push API 和 Pull API

    RabbitMQ 中针对消息的分发提供了 Push API (订阅模式) 和 Pull API (主动获取) 两种模式. 在 PHP 中, 这两种模式分别通过 AMQPQueue 类中的 consum ...

  5. Delphi最简化异步选择TCP服务器

    网上Delphi的Socket服务器优良代码,实在少见,索性写个简化的异步Socket服务器,虽然代码较少,但却该有的都有了,使用的是异步选择WSAAsyncSelect,减少了编写线程的繁琐.可能会 ...

  6. python闭包浅见

    1.个人理解定义:在一个函数A内部定义一个函数B,并在定义的内部函数B内对这个函数A的变量进行引用,那么内部函数B就是闭包. 2.特性:在内部函数内不能对A函数的变量进行更改 (但是可以将其封装到一个 ...

  7. Python列表、元组、字典、集合的内置使用方法

    列表: 是一种可以存储多个值得数据容器 内容是有序的 可以存储任何数据类型 可以存储重复的元素 是可变类型(当内容发生变化时id不变) 元组: 也是一种可以存储多个值得数据容器 元组中的元素不可以被修 ...

  8. nodejs学习(一) ---- nodejs + express应用生成器 快速创建应用

    1.node安装及环境配置(自行百度) 2.express安装及配置 (自行百度) 3.通过应用生成器工具 express 快速创建应用骨架   全局安装应用生成器 : npm install exp ...

  9. php7 安装swoole扩展

    昨天无意中看到一篇关于直播的视频教程 里面讲到了swoole,对于这个东西我相信大家(接近1年phper)都是听过它,但没有真正去用它,当然也是不知道如何使用(me too). 此处总结一下(借鉴了几 ...

  10. Win8系统下MT4不能添加指标无法找到技术指标

    首次使用MT4平台时系统会将MT4所有文件都加载到了Windows用户目录下,导致在MT4安装位置添加了技术指标后,MT4平台也无法找到技术指标,关于这个问题的解决方法如下 MT4是一款享誉盛名的市场 ...