Spring MVC表格导出EXCEL_springmvc导出excel表格 csdn-程序员宅基地

技术标签: EXCEL  Spring MVC  实用代码  

1.pom文件加入依赖,这里我们使用poi来进行EXCEL的操作

		<dependency>
			<groupId>org.apache.poi</groupId>
			<artifactId>poi</artifactId>
			<version>3.9</version>
		</dependency>
		<dependency>  
		    <groupId>org.apache.poi</groupId>  
		    <artifactId>poi-ooxml</artifactId>  
		    <version>3.9</version>  
		</dependency> 

2.RequestMapping到controller层进行代码编写

	public void exportRealTimeRankingExcel(HttpServletRequest request, HttpServletResponse response){
		try {  
			EquipMent em=new EquipMent();
			em.setOrderDeriction("DESC");
			em.setOrderElement("t.pmten");
			em.setOffset(0);
			em.setLimit(10000);
			List<EquipMent> list=construcCmsService.queryAllEquipmentPager(em);
            String title =CalendarUtil.getCurrentDay()+"工地扬尘监测数据";  
            String[] rowsName=new String[]{"污染程度排名","工程名称","设备编号","设备型号",
            		"温度","湿度","pm2.5","pm10","pm100","噪音","风速","风向值","风向",
            		"大气压","md5验证码","设备数据时间","保存时间"};  
            List<Object[]>  dataList = new ArrayList<Object[]>();  
            Object[] objs = null;  
            for (int i = 0; i < list.size(); i++) {  
            	EquipMent po =list.get(i);  
                objs = new Object[rowsName.length];  
                objs[0] = i+1;  
                objs[1] = po.getPname();  
                objs[2] = po.getEcode();  
                objs[3] = po.getEModel();  
                objs[4] = po.getTemperature();  
                objs[5] = po.getHumidity();
                objs[6] = po.getPmTwo();
                objs[7] = po.getPmTen();
                objs[8] = po.getPmHundred();
                objs[9] = po.getTsp();
                objs[10] = po.getWindSpeed();
                objs[11] = po.getWindDeriction();
                if(null!=po.getWindDeriction()){
                	objs[12] = WindDerectionParse.parseDerection(Double.parseDouble(po.getWindDeriction()));
                }else{
                	objs[12] = "未知";
                }
                
                objs[13] = po.getAtmosphere();
                objs[14] = po.getMdFiveCode();
                objs[15] = po.getMonitordataSaveTime();
                objs[16] = po.getMonitorsaveTime();
                dataList.add(objs);  
            }  
            //   
            ExportUtil ex =new ExportUtil(title, rowsName, dataList,response);  
            ex.exportData();  
        } catch (Exception e) {  
            e.printStackTrace();  
        }  
	}

3.ExportUtil 是核心代码,可以直接编写成工具类方便调用

package com.isoftstone.cdds.common.util;

import java.io.IOException;
import java.io.OutputStream;
import java.net.URLEncoder;
import java.util.ArrayList;
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.HSSFRichTextString;
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.apache.poi.ss.util.CellRangeAddress;

public class ExportUtil {
	private String title; // 导出表格的表名  
    
    private String[] rowName;// 导出表格的列名  
      
    private List<Object[]>  dataList = new ArrayList<Object[]>(); // 对象数组的List集合  
      
    private HttpServletResponse  response;  
      
  
    // 传入要导入的数据  
    public ExportUtil(String title,String[] rowName,List<Object[]>  dataList,HttpServletResponse  response){  
        this.title=title;  
        this.rowName=rowName;  
        this.dataList=dataList;  
        this.response = response;  
    }  
      
    // 导出数据  
    public void exportData(){  
        try {  
            HSSFWorkbook workbook =new HSSFWorkbook(); // 创建一个excel对象  
            HSSFSheet sheet =workbook.createSheet(title); // 创建表格  
            // 产生表格标题行  
            HSSFRow rowm  =sheet.createRow(0);  // 行  
            HSSFCell cellTiltle =rowm.createCell(0);  // 单元格  
              
            // sheet样式定义  
            HSSFCellStyle columnTopStyle = this.getColumnTopStyle(workbook); // 头样式  
            HSSFCellStyle style = this.getStyle(workbook);  // 单元格样式  
            /**  
             * 参数说明  
             * 从0开始   第一行 第一列 都是从角标0开始  
             * 行 列 行列    (0,0,0,5)  合并第一行 第一列  到第一行 第六列  
             * 起始行,起始列,结束行,结束列  
             *   
             * new Region()  这个方法使过时的  
             */  
            // 合并第一行的所有列  
            sheet.addMergedRegion(new CellRangeAddress(0, (short) 0, 0, (short) (rowName.length-1)));  
            cellTiltle.setCellStyle(columnTopStyle);  
            cellTiltle.setCellValue(title);   
              
            int columnNum = rowName.length;  // 表格列的长度  
            HSSFRow rowRowName = sheet.createRow(1);  // 在第二行创建行  
            HSSFCellStyle cells =workbook.createCellStyle();  
            cells.setBottomBorderColor(HSSFColor.BLACK.index);    
            rowRowName.setRowStyle(cells);  
              
            // 循环 将列名放进去  
            for (int i = 0; i < columnNum; i++) {  
                HSSFCell  cellRowName = rowRowName.createCell((int)i);  
                cellRowName.setCellType(HSSFCell.CELL_TYPE_STRING); // 单元格类型  
                  
                HSSFRichTextString text = new HSSFRichTextString(rowName[i]);  // 得到列的值  
                cellRowName.setCellValue(text); // 设置列的值  
                cellRowName.setCellStyle(columnTopStyle); // 样式  
            }  
              
            // 将查询到的数据设置到对应的单元格中  
            for (int i = 0; i < dataList.size(); i++) {  
                Object[] obj = dataList.get(i);//遍历每个对象  
                HSSFRow row = sheet.createRow(i+2);//创建所需的行数  
                for (int j = 0; j < obj.length; j++) {  
                     HSSFCell  cell = null;   //设置单元格的数据类型   
                     if(j==0){  
                         // 第一列设置为序号  
                         cell = row.createCell(j,HSSFCell.CELL_TYPE_NUMERIC);  
                         cell.setCellValue(i+1);  
                     }else{  
                         cell = row.createCell(j,HSSFCell.CELL_TYPE_STRING);  
                         if(!"".equals(obj[j]) && obj[j] != null){    
                                cell.setCellValue(obj[j].toString());                       //设置单元格的值    
                            }else{  
                                cell.setCellValue("  ");  
                            }    
                     }  
                     cell.setCellStyle(style); // 样式  
                }  
            }  
            //  让列宽随着导出的列长自动适应  
             sheet.autoSizeColumn((short)0); //调整第一列宽度  
             sheet.autoSizeColumn((short)1); //调整第二列宽度  
             sheet.autoSizeColumn((short)2); //调整第三列宽度  
             sheet.autoSizeColumn((short)3); //调整第四列宽度  
             sheet.autoSizeColumn((short)4); //调整第五列宽度  
             sheet.autoSizeColumn((short)5); //调整第六列宽度  
               
             if(workbook !=null){    
                    try    
                    {    
                        // excel 表文件名  
                        String fileName = title + String.valueOf(System.currentTimeMillis()).substring(4, 13) + ".xls";    
                        String fileName11 = URLEncoder.encode(fileName,"UTF-8");  
                        String headStr = "attachment; filename=\"" + fileName11 + "\"";    
                        response.setContentType("APPLICATION/OCTET-STREAM");    
                        response.setHeader("Content-Disposition", headStr);    
                        OutputStream out = response.getOutputStream();    
                        workbook.write(out);  
                        out.flush();  
                        out.close();  
                    }    
                    catch (IOException e)    
                    {    
                        e.printStackTrace();    
                    }   
                      
                }    
        
            }catch(Exception e){    
                e.printStackTrace();    
            }    
                
        }    
              
    public HSSFCellStyle getColumnTopStyle(HSSFWorkbook workbook) {    
          
        // 设置字体    
        HSSFFont font = workbook.createFont();    
        //设置字体大小    
        font.setFontHeightInPoints((short)11);    
        //字体加粗    
        font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);    
        //设置字体名字     
        font.setFontName("Courier New");    
        //设置样式;     
        HSSFCellStyle style = workbook.createCellStyle();    
        //设置底边框;     
        style.setBorderBottom(HSSFCellStyle.BORDER_THIN);    
        //设置底边框颜色;      
        style.setBottomBorderColor(HSSFColor.BLACK.index);    
        //设置左边框;       
        style.setBorderLeft(HSSFCellStyle.BORDER_THIN);    
        //设置左边框颜色;     
        style.setLeftBorderColor(HSSFColor.BLACK.index);    
        //设置右边框;     
        style.setBorderRight(HSSFCellStyle.BORDER_THIN);    
        //设置右边框颜色;     
        style.setRightBorderColor(HSSFColor.BLACK.index);    
        //设置顶边框;     
        style.setBorderTop(HSSFCellStyle.BORDER_THIN);    
        //设置顶边框颜色;      
        style.setTopBorderColor(HSSFColor.BLACK.index);    
        //在样式用应用设置的字体;      
        style.setFont(font);    
        //设置自动换行;     
        style.setWrapText(false);    
        //设置水平对齐的样式为居中对齐;      
        style.setAlignment(HSSFCellStyle.ALIGN_CENTER);    
        //设置垂直对齐的样式为居中对齐;     
        style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);    
            
        return style;    
            
  }    
      
    public HSSFCellStyle getStyle(HSSFWorkbook workbook) {    
        // 设置字体    
        HSSFFont font = workbook.createFont();    
        //设置字体大小    
        //font.setFontHeightInPoints((short)10);    
        //字体加粗    
        //font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);    
        //设置字体名字     
        font.setFontName("Courier New");    
        //设置样式;     
        HSSFCellStyle style = workbook.createCellStyle();    
        //设置底边框;     
        style.setBorderBottom(HSSFCellStyle.BORDER_THIN);    
        //设置底边框颜色;      
        style.setBottomBorderColor(HSSFColor.BLACK.index);    
        //设置左边框;       
        style.setBorderLeft(HSSFCellStyle.BORDER_THIN);    
        //设置左边框颜色;     
        style.setLeftBorderColor(HSSFColor.BLACK.index);    
        //设置右边框;     
        style.setBorderRight(HSSFCellStyle.BORDER_THIN);    
        //设置右边框颜色;     
        style.setRightBorderColor(HSSFColor.BLACK.index);    
        //设置顶边框;     
        style.setBorderTop(HSSFCellStyle.BORDER_THIN);    
        //设置顶边框颜色;      
        style.setTopBorderColor(HSSFColor.BLACK.index);    
        //在样式用应用设置的字体;      
        style.setFont(font);    
        //设置自动换行;     
        style.setWrapText(false);    
        //设置水平对齐的样式为居中对齐;      
        style.setAlignment(HSSFCellStyle.ALIGN_CENTER);    
        //设置垂直对齐的样式为居中对齐;     
        style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);    
           
        return style;    
  }    
}

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/u013886444/article/details/100066833

智能推荐

java+标签定位_Java + selenium 元素定位(3)之By TagName-程序员宅基地

文章浏览阅读779次。本篇介绍findElement接口中的By TagName方法。首先,要知道什么是tagname。之前我们使用F12开发者工具查看网页元素是,发现每行代码前都有、、、等等标签,这些标签就是tagname了。但是我们都可以看出来,像是、、这些常用的标签,在网页中出现的频率是很高的,如果我们使用tagname来定位元素,可能定位到的就不是我们预想的元素。所以一般配合findElements接口使用,查..._tagname定位

一套开源快速开发平台--若依(ruoyi)_若依是什么-程序员宅基地

文章浏览阅读1w次,点赞3次,收藏36次。简介:① 若依(ruoyi)是一套全部开源的快速开发平台,毫无保留给个人及企业免费使用。② 前端采用Vue、Element UI。③ 后端采用Spring Boot、Spring Security、Redis & Jwt。④ 权限认证使用Jwt,支持多终端认证系统。⑤ 支持加载动态权限菜单,多方式轻松权限控制。⑥ 高效率开发,使用代码生成器可以一键生成前后端代码。如何获取若依?若依是一套开源的项目,可以直接下载使用。从码云cope项目idea新建并打开项目导入S_若依是什么

MySQL 5.7安装教程_mysql5.7.41安装教程-程序员宅基地

文章浏览阅读4.6k次,点赞3次,收藏13次。MySQL5.7安装教程。_mysql5.7.41安装教程

个人技术博客的选择:CSDN、博客园、简书、知乎专栏、Github、新浪、个人建站等?_github和csdn的区别-程序员宅基地

文章浏览阅读1w次,点赞19次,收藏47次。个人技术博客的选择:CSDN、博客园、简书、个人建站、知乎专栏、Github Page、新浪?引言:为什么写博客一晃也干了十多年的技术了,也经常穿梭于各种技术论坛之中,得益于各位大V博主的无私奉献。我也想效仿各位博主前辈,一方面是自己知识的总结,一方面也是知识的分享(幼儿园老师不是说过么,要学会分享~~)。最近终于有点时间了,然后发现现在博客平台很多,突然不知从何下手了。于是在网上一顿狂搜,..._github和csdn的区别

极简hooks实现,与react的思路一样的useState_workinprogresshook-程序员宅基地

文章浏览阅读1.5k次。使用App函数模拟根组件 function App() { const [num, updateNum] = useState(0); console.log(`${isMount ? "mount" : "update"} num: `, num); button.textContent = num; return { click() { updateNum((num) => num + _workinprogresshook

3种MFC弹出对话框的方法-程序员宅基地

文章浏览阅读1.2w次,点赞7次,收藏54次。一、点击菜单按钮弹出对话框1、在资源视图中(.rc文件夹下)找到menu,选择需要弹框的菜单项;2、点击菜单项,修改菜单ID,在主程序中用ON_COMMAND()将ID和函数关联,要在主程序的头文件中声明被关联函数;例:菜单ID和函数关联ON_COMMAND(ID_Task,&CMFCExampleView::OnCreateTask)声明函数afx_msg void OnCreateTask();3、在资源视图中(.rc文件夹下)添加Dialog,为对话框创_mfc弹出对话框

随便推点

1 python数据分析基础——xlwings模块与pandas模块的交互_xlwings pandas-程序员宅基地

文章浏览阅读3.4k次,点赞3次,收藏19次。模块与模块之间是可以交互的。例如,用pandas模块创建数据表格,再用xlwings模块将表格写入工作簿。具体代码如下:_xlwings pandas

再见,秋招!再战,春招!_再战秋招可行吗-程序员宅基地

文章浏览阅读1k次,点赞3次,收藏3次。再见,秋招!再战,春招!整个秋招,我领悟到:实力很重要运气有时候这东西说不好原罪其实还是:自己太菜!回顾这几年在学校的时候,做了两年 Web 开发,接学校项目,接外包,靠着两手 PHP 和 jQuery 自以为很牛逼可以混迹江湖,大二开始,接触机器学习,那时候在学校还没那么火,然后跑去找学长请教怎么学,研究怎么做 Kaggle/天池,买了很多很多书,刷西瓜书、刷了好几遍统计学习方..._再战秋招可行吗

郑州大学本科生毕业论文latex模板_`\llll-程序员宅基地

文章浏览阅读4.1k次,点赞7次,收藏15次。反复修改了几次,提供一份版本最新最完美也是我毕业论文用到的一个模板。文档类zzuThesis.cls\ProvidesClass{zzuThesis}[2017/06/02 v3.0, by Lu Song]%版本3.0%修复了题目不能自动换行的问题%添加了中文注释%去掉一些重复的命令%修复了一些警告和一些小bug%去掉节前的S编号,修改页眉%把目录放在前面%将英文摘要放入目录%_`\llll

Qt 中设置窗口边框的圆角_qt 设置窗口边框为实线,设置窗口圆弧拐角-程序员宅基地

文章浏览阅读1.4w次,点赞3次,收藏15次。转载自:http://blog.csdn.net/goforwardtostep/article/details/52084538Qt在设置窗口边框圆角时有两种方式,一种是设置样式,另一种是在paintEvent事件中绘制窗口。下面分别叙述用这两种方式来实现窗口边框圆角的效果。一、使用setStyleSheet方法this->setStyleSheet(_qt 设置窗口边框为实线,设置窗口圆弧拐角

KCF源码下载-程序员宅基地

文章浏览阅读397次,点赞3次,收藏6次。刚接触CV领域,想在MATLAB上跑一下KCF算法,还特意在csdn下载了一个C++代码,又是配VS又是配OpenCV,不好用…直接链接KCF作者网页链接下滑找到KCF文章论文pdf、MATLAB代码、C++代码全在_kcf源码

对抗样本之DeepFool原理&coding-程序员宅基地

文章浏览阅读3.3k次,点赞4次,收藏38次。目录1 笔者言2 coding2.1 训练模型2.2 DeepFool对抗样本生成2.3 测试鲁棒性2.4 可视化展示附录1 笔者言虽说标题有DeepFool原理,但能力有限,这个我确实讲不清楚。与FGSM,BIM,MIM,CW等生成对抗样本的方法相比,deepfool是最难的了。给你推荐一个我看懂了的文章,但切记,想要真正明白deepfool的原理,就一定要耐下性子认真看,还要多动笔画示意图。言至此,传送门本文主要讲解代码,完成生成deepfool对抗样本的完整过程。直接复制代码就能跑。相信我,不_deepfool

推荐文章

热门文章

相关标签