spring mvc poi excel
- Util类
- package com.common.util;
- public class ExportUtil
- {
- private XSSFWorkbook wb = null;
- private XSSFSheet sheet = null;
- /**
- * @param wb
- * @param sheet
- */
- public ExportUtil(XSSFWorkbook wb, XSSFSheet sheet)
- {
- this.wb = wb;
- this.sheet = sheet;
- }
- /**
- * 合并单元格后给合并后的单元格加边框
- *
- * @param region
- * @param cs
- */
- public void setRegionStyle(CellRangeAddress region, XSSFCellStyle cs)
- {
- int toprowNum = region.getFirstRow();
- for (int i = toprowNum; i <= region.getLastRow(); i++)
- {
- XSSFRow row = sheet.getRow(i);
- for (int j = region.getFirstColumn(); j <= region.getLastColumn(); j++)
- {
- XSSFCell cell = row.getCell(j);// XSSFCellUtil.getCell(row,
- // (short) j);
- cell.setCellStyle(cs);
- }
- }
- }
- /**
- * 设置表头的单元格样式
- *
- * @return
- */
- public XSSFCellStyle getHeadStyle()
- {
- // 创建单元格样式
- XSSFCellStyle cellStyle = wb.createCellStyle();
- // 设置单元格的背景颜色为淡蓝色
- cellStyle.setFillForegroundColor(HSSFColor.PALE_BLUE.index);
- cellStyle.setFillPattern(XSSFCellStyle.SOLID_FOREGROUND);
- // 设置单元格居中对齐
- cellStyle.setAlignment(XSSFCellStyle.ALIGN_CENTER);
- // 设置单元格垂直居中对齐
- cellStyle.setVerticalAlignment(XSSFCellStyle.VERTICAL_CENTER);
- // 创建单元格内容显示不下时自动换行
- cellStyle.setWrapText(true);
- // 设置单元格字体样式
- XSSFFont font = wb.createFont();
- // 设置字体加粗
- font.setBoldweight(XSSFFont.BOLDWEIGHT_BOLD);
- font.setFontName("宋体");
- font.setFontHeight((short) 200);
- cellStyle.setFont(font);
- // 设置单元格边框为细线条
- cellStyle.setBorderLeft(XSSFCellStyle.BORDER_THIN);
- cellStyle.setBorderBottom(XSSFCellStyle.BORDER_THIN);
- cellStyle.setBorderRight(XSSFCellStyle.BORDER_THIN);
- cellStyle.setBorderTop(XSSFCellStyle.BORDER_THIN);
- return cellStyle;
- }
- /**
- * 设置表体的单元格样式
- *
- * @return
- */
- public XSSFCellStyle getBodyStyle()
- {
- // 创建单元格样式
- XSSFCellStyle cellStyle = wb.createCellStyle();
- // 设置单元格居中对齐
- cellStyle.setAlignment(XSSFCellStyle.ALIGN_CENTER);
- // 设置单元格垂直居中对齐
- cellStyle.setVerticalAlignment(XSSFCellStyle.VERTICAL_CENTER);
- // 创建单元格内容显示不下时自动换行
- cellStyle.setWrapText(true);
- // 设置单元格字体样式
- XSSFFont font = wb.createFont();
- // 设置字体加粗
- font.setBoldweight(XSSFFont.BOLDWEIGHT_BOLD);
- font.setFontName("宋体");
- font.setFontHeight((short) 200);
- cellStyle.setFont(font);
- // 设置单元格边框为细线条
- cellStyle.setBorderLeft(XSSFCellStyle.BORDER_THIN);
- cellStyle.setBorderBottom(XSSFCellStyle.BORDER_THIN);
- cellStyle.setBorderRight(XSSFCellStyle.BORDER_THIN);
- cellStyle.setBorderTop(XSSFCellStyle.BORDER_THIN);
- return cellStyle;
- }
- }
- service类
- public interface ITestExportExcelService
- {
- public void exportExcel(String hql,String [] titles,ServletOutputStream outputStream);
- }
- @Service
- public class TestExportExcelServiceImpl implements ITestExportExcelService
- {
- @Resource
- private ITestExportExcelDao dao;
- public void exportExcel(String hql, String[] titles, ServletOutputStream outputStream)
- {
- List<Goods> list = dao.exportExcel(hql);
- // 创建一个workbook 对应一个excel应用文件
- XSSFWorkbook workBook = new XSSFWorkbook();
- // 在workbook中添加一个sheet,对应Excel文件中的sheet
- XSSFSheet sheet = workBook.createSheet("导出excel例子");
- ExportUtil exportUtil = new ExportUtil(workBook, sheet);
- XSSFCellStyle headStyle = exportUtil.getHeadStyle();
- XSSFCellStyle bodyStyle = exportUtil.getBodyStyle();
- // 构建表头
- XSSFRow headRow = sheet.createRow(0);
- XSSFCell cell = null;
- for (int i = 0; i < titles.length; i++)
- {
- cell = headRow.createCell(i);
- cell.setCellStyle(headStyle);
- cell.setCellValue(titles[i]);
- }
- // 构建表体数据
- if (list != null && list.size() > 0)
- {
- for (int j = 0; j < list.size(); j++)
- {
- XSSFRow bodyRow = sheet.createRow(j + 1);
- Goods goods = list.get(j);
- cell = bodyRow.createCell(0);
- cell.setCellStyle(bodyStyle);
- cell.setCellValue(goods.getGoodsName());
- cell = bodyRow.createCell(1);
- cell.setCellStyle(bodyStyle);
- cell.setCellValue(goods.getGoodsCost());
- cell = bodyRow.createCell(2);
- cell.setCellStyle(bodyStyle);
- cell.setCellValue(goods.getGoodsUnit());
- }
- }
- try
- {
- workBook.write(outputStream);
- outputStream.flush();
- outputStream.close();
- }
- catch (IOException e)
- {
- e.printStackTrace();
- }
- finally
- {
- try
- {
- outputStream.close();
- }
- catch (IOException e)
- {
- e.printStackTrace();
- }
- }
- }
- }
- dao类
- public interface ITestExportExcelDao
- {
- public List<Goods> exportExcel(String hql);
- }
- @Repository
- public class TestExportExcelDaoImpl implements ITestExportExcelDao
- {
- @Resource
- private SessionFactory factory;
- /**
- * 以goods表为例导出测试
- */
- @SuppressWarnings("unchecked")
- public List<Goods> exportExcel(String hql)
- {
- Session session = factory.getCurrentSession();
- List<Goods> list = session.createQuery(hql).list();
- return list;
- }
- }
- 控制层Controller
- @Controller
- @RequestMapping("/testexportexcel/*")
- public class TestExportExcelController
- {
- @Resource
- private ITestExportExcelService service;
- @RequestMapping
- public String exportExcel(HttpServletResponse response)
- {
- response.setContentType("application/binary;charset=ISO8859_1");
- try
- {
- ServletOutputStream outputStream = response.getOutputStream();
- String fileName = new String(("导出excel例子").getBytes(), "ISO8859_1");
- response.setHeader("Content-disposition", "attachment; filename=" + fileName + ".xlsx");// 组装附件名称和格式
- String hql = "from Goods";
- String[] titles = { "商品名", "商品单价", "商品单位" };
- service.exportExcel(hql, titles, outputStream);
- }
- catch (IOException e)
- {
- e.printStackTrace();
- }
- return null;
- }
- @RequestMapping
- public String upload(HttpServletRequest request, HttpServletResponse response)
- {
- MultipartHttpServletRequest mulRequest = (MultipartHttpServletRequest) request;
- MultipartFile file = mulRequest.getFile("excel");
- String filename = file.getOriginalFilename();
- if (filename == null || "".equals(filename))
- {
- return null;
- }
- try
- {
- InputStream input = file.getInputStream();
- XSSFWorkbook workBook = new XSSFWorkbook(input);
- XSSFSheet sheet = workBook.getSheetAt(0);
- if (sheet != null)
- {
- for (int i = 1; i < sheet.getPhysicalNumberOfRows(); i++)
- {
- XSSFRow row = sheet.getRow(i);
- for (int j = 0; j < row.getPhysicalNumberOfCells(); j++)
- {
- XSSFCell cell = row.getCell(j);
- String cellStr = cell.toString();
- System.out.print("【"+cellStr+"】 ");
- }
- System.out.println();
- }
- }
- }
- catch (Exception e)
- {
- e.printStackTrace();
- }
- return "/test/uploadExcel.jsp";
- }
- }
spring mvc poi excel的更多相关文章
- spring mvc 导出 excel
// js 触发导出 excel 方法 导出当前页的数据 含有条件查询的结果 // js 框架使用的 是 easyui function doExport(){ var optins = $(&quo ...
- spring mvc的excel报表文件下载时流的冲突解决
在jsp或者在servlet中有时要用到 response.getOutputStream(),但是此时会在后台报这个错误java.lang.IllegalStateException: getOut ...
- Spring MVC 实现Excel的导入导出功能(1:Excel的导入)
简介 这篇文章主要记录自己学习上传和导出Excel时的一些心得,企业办公系统的开发中,经常会收到这样的需求:批量录入数据.数据报表使用 Excel 打开,或者职能部门同事要打印 Excel 文件,而他 ...
- Spring MVC 实现Excel的导入导出功能(2:Excel的导入优化和Excel的导出)
Excel的导入V2优化版 有些时候文件上传这一步骤由前端来处理,只将上传后的 URL 传输给后端(可以参考上一文中的图片上传功能),也就是导入请求中并不会直接处理 MultipartFile 对象, ...
- spring mvc项目中导出excel表格简单实现
查阅了一些资料,才整理出spring mvc 项目导出excel表格的实现,其实很是简单,小计一下,方便以后查阅,也希望帮助有需要的朋友. 1.导入所需要依赖(Jar包).我使用的是maven,所以坐 ...
- Spring MVC 实例:Excel视图的使用
对于Excel而言,Spring MVC所推荐的是使用AbstractXlsView,它实现了视图接口,从其命名也可以知道它只是一个抽象类,不能生成实例对象.它自己定义了一个抽象方法——buildEx ...
- 基于Spring Mvc实现的Excel文件上传下载
最近工作遇到一个需求,需要下载excel模板,编辑后上传解析存储到数据库.因此为了更好的理解公司框架,我就自己先用spring mvc实现了一个样例. 基础框架 之前曾经介绍过一个最简单的spring ...
- Spring MVC 学习总结(三)——请求处理方法Action详解
Spring MVC中每个控制器中可以定义多个请求处理方法,我们把这种请求处理方法简称为Action,每个请求处理方法可以有多个不同的参数,以及一个多种类型的返回结果. 一.Action参数类型 如果 ...
- EasyUI + Spring MVC + hibernate实现增删改查导入导出
(这是一个故事--) 前言 作为一个JAVA开发工程师,我觉得最基本是需要懂前端.后台以及数据库. 练习的内容很基础,包括:基本增删改查.模糊查询.分页查询.树菜单.上传下载.tab页 主管发我一个已 ...
随机推荐
- linux C之access函数(转载)
转自:http://blog.sina.com.cn/s/blog_6a1837e90100uh5d.html access():判断是否具有存取文件的权限 相关函数 stat,open,chm ...
- Node学习图文教程之express重写留言本案例
写在前面 小伙伴们大家好,我是你们的pubdreamcc,接着前面的学习,这篇博文出至于我的GitHub仓库:Node学习教程资料,如果你觉得对你有帮助,欢迎star,你们的点赞是我持续更新的动力,谢 ...
- 20170407-ms
invoke v调用 dismiss v解雇 exclusive adj. 专用的; 高级的; 排外的; 单独的; n. 独家新闻; 专有物; 独家经营的产品(或项目.设计等); 排外者; ex ...
- 洛谷 - P1433 - 吃奶酪 - dfs
https://www.luogu.org/problemnew/show/P1433 并不是每一个求最短距离就是bfs,这个肯定是dfs. 直接计算15!可以知道枚举必定超时,但是! 我们dfs非常 ...
- POJ1961(kmp中Next数组的性质)
对于某个位置i,i - Next[i]是循环节长度,i整除(i - Next[i])时是完整的几个循环元. ; int n, kase, Next[maxn]; char ch[maxn]; inli ...
- 1-18String类简介
字符串(String)的不可变性 String类在java.lang包下面,是Object类的直接子类,通过API或者源码可以看到,String类是final修饰的,这说明String类不能被继承. ...
- 1-17finally关键字
finally的特点 被finally控制的语句体一定会执行,除非在执行finally语句体之前JVM退出(比如System.exit(0)),一般用于关闭资源 finally如何使用? finall ...
- Lock wait timeout exceeded; try restarting transaction linux设置mysql innodb_lock_wait_timeout
root权限下: vi /etc/my.cnf 在[mysqld]配置下面加入 innodb_lock_wait_timeout=value # value是你想设置的值 重启mysql /etc/i ...
- AJPFX辨析Java中运算符 ++ 和 += 的区别
我们都知道Java中 ++ 和 +=1 都是把数字增加一后,把值赋给左边,那二者有什么区别呢? i+=1 运行的底层Heap申请一个区域存放i,在数据区域开劈一个区域存放1,2个内存段被数据被送入到 ...
- 复习-PEP8规范(转)
PEP8 Python 编码规范 一 代码编排1 缩进.4个空格的缩进(编辑器都可以完成此功能),不使用Tap,更不能混合使用Tap和空格.2 每行最大长度79,换行可以使用反斜杠,最好使用圆括号.换 ...