java后台处理excel_java后台利用Apache poi 生成excel文档提供前台下载示例

之前在项目中会用到在java在后台把数据填入Word文档的模板来提供前台下载,为了自己能随时查看当时的实现方案及方便他人学习我写了这篇博客,访问量已经是我写的博客里第一了。于是乎我在学会用Java在后台利用Apache poi 生成excel文档提供前台下载之后就想着来写一篇姊妹篇啦。

在生成Excel文档的时候我采用了和生成Word时的不同方法,Apache poi。它是用Java编写的免费开源的跨平台的 Java API,提供API给Java程式对Microsoft Office格式档案读和写的功能。想要实现这个功能,就按照下面的步骤来做吧,为了方便起见,我直接拿项目中遇到的实例来举例说明,是的,我在写这篇博客的时候同时也在完成手上的项目。

step1:创建xls格式的模板

表头含有我的甲方信息就打码了,可以看到我搞了一个空的模板文件,现在有很多东西需要在后台填入

8081857d46221a644442c70c3f0b54d4.png

step2:前台触发事件

搞一个按钮,用户点击的时候用javascript的window.location.href将页面重定向到你处理下载的URL去

比方说,这是我项目的前台,看到那个表面质量按钮吗,来看一下当它被点击的时候调用的函数

e889bfccfb1140930be38c22004e1714.png

function exportBatch() {

//get请求,可以传递参数,比方说我这里就传了一堆卷号,我只生成传过去的这堆卷号的检验记录

//参数rollNumbers的细节就不展示了,业务相关

window.location.href = '../ir/exportSurface?rollNumberList=' + rollNumbers;

}

有朋友可能想用什么Ajax来发送请求,我反正是没搞出来,挺麻烦的,网上找的相关解决方案也都比较蛋疼,因此不传什么复杂的敏感的参数,就这么写就可以。

step3:后台处理

首先你当然要把Apache poi那一套东西引入你的项目啦,我的项目是Maven项目,添加依赖很容易

org.apache.poi

poi

3.14

然后,为了方便导出Excel,在项目中建了一个ExcelUtils工具类,后面给出源码,这么一来导出Excel会变得更简单。ExcelUtils里面rXogrNBYP除了一些既定的方法外,还有就是你具体怎么去操作模板的方法了。当然你用的少的话可以不用我这工具类,而是在你需要的时候import相关的类,然后在你处理的时候就把操作模板的逻辑写进去也可以。但我这个项目很多次用到导出Excel,所以抽象出一个工具类是很有必要的,符合设计模式。

我的项目是基于SpringMVC的,来看看我后台接收到请求以后做了些什么吧

Controller:

/***

* 批量导出表面质量检验记录

*

* @return

* @throws Exception

*/

@RequestMapping(value = "exportSurface", method = RequestMethod.GET)

@ResponseBody

public void exportSurface(HttpServletRequest request,

HttpServletResponse response) throws Exception {

//参数获取及处理,业务相关不展示

//把要填写的数据放在一个map里

Map map = new HashMap();

map.put("sequence", "0001");//mock编号

map.put("date", DateUtils.toDateStr(new Date(), DateUtils.DEFAULT_DATE_PATTERN_CHINES

最后调用ExcelUtils里的相关导出方法,这个方法是自定义的,它定义的是怎样去操作模板

自定义的方法:

public static void exportInspectionRecordSurface(HttpServletRequest request, HttpServletResponse response, Map map) throws IOException {

//模板的路径,这个在自己的项目中很容易弄错,相对位置一定要写对啊

String prXogrNBYPsth = request.getRealPath("/") + INSPECTIONRECORD_SURFACE_TEMPLET_PATH;

Workbook webBook = readExcel(psth);

createCellStyle(webBook);

Sheet sheet = webBook.getSheetAt(0);

//开始操作模板,找到某行某列(某个cell),需要注意的是这里有个坑,行和列的计数都是从0开始的

//一次数据插入的位置不对,别灰心,多试几次就好啦,你要是能看懂我下面的代码,数据插在了什么位置,你就明白了

int rows = 1;

Row row = sheet.getRow(rows);

row.createCell(1).setCellValue((String) map.get("sequence"));

row.createCell(3).setCellValue((String) map.get("date"));

row.createCell(9).setCellValue((String) map.get("chetaihao"));

rows = 2;

row = sheet.getRow(rows);

row.createCell(1).setCellValue((String) map.get("productName"));

row.createCell(3).setCellValue((String) map.get("specification"));

row.createCell(9).setCellValue((String) map.get("memo"));

//检验记录的插入业务相关,不展示,其实就是for循环在合适的行合适的列插入一个个对象的属性即可,你这么聪明,没问题的

writeExcel(response, webBook, "表面质量检验记录");

}

ExcelUtils:

//这里得有你自己的package名

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.HSSFWorkbook;

import org.apache.poi.ss.usermodel.*;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import java.io.*;

import java.net.URLEncoder;

import java.util.ArrayList;

import java.util.List;

import java.util.Map;

/**

* Created by bwju on 2016/12/06.

*/

public class ExcelUtils {

private static final String INSPECTIONRECORD_SURFACE_TEMPLET_PATH = "/asserts/templete/InspectionRecordSurface.xls";

private static HSSFCellStyle cellstyle = null;

public static void exportInspectionRecordSurface(HttpServletRequest request, HttpServletResponse response, Map map) throws IOException {

//实现上文里有,改个函数名,写你的操作模板函数吧!

}

private static Workbook readExcel(String filePath) {

InputStream in = null;

Workbook work = null;

try {

in = new FileInputStream(filePath);

work = new HSSFWorkbook(in);

} catch (FileNotFoundException e) {

System.out.println("文件路径错误");

e.printStackTrace();

} catch (IOException e) {

System.out.println("文件输入流错误");

e.printStackTrace();

}

return work;

}rXogrNBYP

private static void writeExcel(HttpServletResponse response, Workbook work, String fileName) throws IOException {

OutputStream out = null;

try {

out = response.getOutputStream();

response.setContentType("application/ms-excel;charset=UTF-8");

response.setHeader("Content-Disposition", "attachment;filename="

.concat(String.valueOf(URLEncoder.encode(fileName + ".xls", "UTF-8"))));

work.write(out);

} catch (IOException e) {

System.out.println("输出流错误");

e.printStackTrace();

} finally {

out.close();

}

}

private static Cell setCellStyleWithStyleAndValue(CellStyle style, Cell cell, String value) {

cell.setCellStyle(style);

cell.setCellValue(value);

return cell;

}

private static Cell setCellStyleWithValue(Cell cell, String value) {

cell.setCellStyle(cellstyle);

cell.setCellValue(value);

return cell;

}

private static Cell setCellStyleWithStyleAndValue(CellStyle style, Cell cell, RichTextString value) {

cell.setCellStyle(style);

cell.setCellValue(value);

return cell;

}

private static Cell setCellStyleWithValue(Cell cell, int value) {

cell.setCellStyle(cellstyle);

cell.setCellValue(value);

return cell;

}

private static Cell setCellStyleWithValue(Cell cell, double value) {

cell.setCellStyle(cellstyle);

cell.setCellValue(value);

return cell;

}

private static HSSFCellStyle createCellStyle(Workbook wb) {

cellstyle = (HSSFCellStyle) wb.createCellStyle();

cellstyle.setAlignment(HSSFCellStyle.ALIGN_CENwww.cppcns.comTER);

cellstyle.setBorderBottom(HSSFCellStyle.BORDER_THIN);

cellstyle.setBorderLeft(HSSFCellStyle.BORDER_THIN);

cellstyle.setBorderRight(HSSFCellStyle.BORDER_THIN);

cellstyle.setBorderTop(HSSFCellStyle.BORDER_THIN);

cellstyle.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);

return cellstyle;

}

}

step4:启动项目,然后测试一下,看!完美的导出了。。。有图为证

30c3e095af80f8f3900cb461f77ea925.png

嗯嗯,文章写到这里就结束啦,Apache poi还提供了很多API在本例中为得到展示,比如能够指定样式等等。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

本文标题: java后台利用Apache poi 生成excel文档提供前台下载示例

本文地址: http://www.cppcns.com/ruanjian/java/190786.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/552522.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java向有序数组里插数_Java向有序数组中插入一个元素,,使其仍按有序排列,并求出这个插入元素的下标...

/*** * create time [2014-4-13]*/public class Test{public static void main(String args[]){//原有序数组,这里约定数组是升序排列int[] intArray new int[]{1,2,4,6,7,9};int toInsert 8;//待插入数据int subscript 0;//下标//确定下标位置if(toInsert {subscript 0;}e…

php 删除文件夹及文件夹,php删除一个路径下的所有文件夹和文件的方法

php遍历一个文件夹内的所有文件和文件夹,并删除所有文件夹和子文件夹下的所有文件的代码,通过递归方式实现达到清空一个目录的效果,代码简单实用。也适合在thinkphp中清理缓存,在thinkphp中可以把下面代码写入./Application/Admin…

PHP制作订货,PHP生成订单号的两种方法

在开发项目的时候经常有生成订单号的需求&#xff0c;这里列出两种生成20位订单号的常用方法。方法一&#xff1a;以下代码是14位当前时间加6位随机数&#xff0c;如果增减位数&#xff0c;只需修改末尾的数字6即可。<?php Function build_order_no(){return date(YmdHis).…

php 分类排序,php将地区分类排序的算法

php将地区分类排序的算法介绍&#xff0c;有需要的朋友可以参考下。写一个函数&#xff0c;用来存储地区数据&#xff1a;复制代码 代码如下:$array array(0>array("","河北"),1>array("","北京"),2>array(0,"保定&quo…

js读写php文件,在js中如何读取本地文件

下面我就为大家分享一篇js读取本地文件的实例&#xff0c;具有很好的参考价值&#xff0c;希望对大家有所帮助。如何用在浏览器端预览本地文件&#xff1f;今天的主题是使用浏览器预览本地文件。由于浏览器安全策略的限制&#xff0c;javascript程序不能自由地访问本地资源&…

php mvc教程 文档,PHP培训教程教你快速打造PHP MVC框架[PHP基础教程]

PHP培训教程教你快速打造PHP MVC框架[PHP基础教程]简介MVC框架在现在的开发中相当流行&#xff0c;不论你使用的是JAVA,C#,PHP或者IOS&#xff0c;你肯定都会选择一款框架。虽然不能保证100%的开发语言都会使用框架&#xff0c;但是在PHP社区当中拥有最多数量的MVC框架。今天你…

java分页代码思路,记录--java 分页 思路 (hibernate关键代码)

有时会脑袋蒙圈&#xff0c;记录下分页的思路下面代码是hibernate的分页&#xff0c;其分页就是从第几条数据为起点&#xff0c;取几条数据。比如在mysql中的limit(5,10)取的就是第6条到第10条在下面代码中的page是页数、size是每页多少条数据String hql"from User";…

php查看运行时间和内存,php 统计时间和内存的使用情况

跳至/*** 记录和统计时间(微秒)和内存使用情况* 使用方法:** G(begin); // 记录开始标记位* // ... 区间运行代码* G(end); // 记录结束标签位* echo G(begin,end,6); // 统计区间运行时间 精确到小数后6位* echo G(begin,end,m); // 统计区间内存使用情况* 如果end标记位没有定…

宝塔php漏洞,[安全预警]关于最近宝塔闹得很厉害的PMA漏洞BUG

文章前言在2020年8月23日的下午有个憨憨管理在我群艾特全员 说宝塔爆出漏洞了赶快更新吧&#xff01;影响机器需同时满足以下所有条件1、软件版本为Linux面板7.4.2 或者Windows面板6.8.02、开放888且未配置http认证&#xff0c;3、安装了phpmyadmin&#xff0c;mysql数据库不受…

求十个学生的平均成绩java,JAVA 声明一个数组,存一个学生的五门成绩。求该学生的总成绩、平均成绩。...

JAVA 声明一个数组,存一个学生的五门成绩。求该学生的总成绩、平均成绩。mip版 关注:116 答案:3 悬赏:30解决时间 2021-01-26 06:39已解决2021-01-25 17:54声明一个数组,存一个学生的五门成绩。求该学生的总成绩、平均成绩。JAVA知识最佳答案2021-01-25 18:12public class S…

php伪静态限制网页播放视频,学习猿地-php伪静态后html不能访问怎么办

php伪静态后html不能访问的解决办法&#xff1a;首先判断文件是否存在&#xff1b;然后设置存在则不rewirte&#xff0c;不存在且符合规则才rewrite&#xff1b;最后修改htaccess文件即可。具体问题&#xff1a;PHP伪静态后不能访问纯html文件.htaccess文件RewriteEngine onRew…

oracle binary_integer pls_integer,oracle中binaryinteger与plsinteger的区别

oracle中binaryinteger与plsinteger的区别 Oracle 中 Binary_Integer 与 Pls_Integer 的区别Binary_Integer 与 Pls_Integer 都是整型类型. Binary_Integer 类型变量值计算是由 Oracle 来执行&#xff0c;不会出现溢出&#xff0c;但是执行速度较慢&#xff0c;因为它是由 Orac…

梁单元分析matlab,[FEM][有限元][编程][Matlab][Code by myself] 2D Timoshenko梁单元

(有空和小伙伴一起写写有限元程序)程序作者 ( Author )JiDong Cui (崔济东)1, XueLong Shen (沈雪龙)21.广州容柏生建筑结构设计事务所&#xff1b;2.华南理工大学建筑设计研究院基本概念 ( Concept )欧拉梁单元基于一定的假设(Kirchhoff假设)&#xff0c;在梁的高度远小于其跨…

oracle保存type类型,oracle type类型

--创建类型说明***********************************************************create or replace type dept_type as object(--成员变量h_deptno number(2),h_dname varchar2(14),h_loc varchar2(13),--成员函数、过程member procedure changedept(name in varchar2,loc in var…

Oracle函数的信息,Oracle中获取会话信息的两个函数分享

1、 USERENV(OPTION)  返回当前的会话信息.OPTION‘ISDBA‘若当前是DBA角色,则为TRUE,否则FALSE.OPTION‘LANGUAGE‘返回数据库的字符集.OPTION‘SESSIONID‘为当前会话标识符.OPTION‘ENTRYID‘返回可审计的会话标识符.OPTION‘LANG‘返回会话语言名称的ISO简记.OPTION‘INS…

oracle分组后伪列,Oracle伪列和伪表和分组函数(row_number,Rank)

oracle的伪列以及伪表oracle系统为了实现完整的关系数据库功能&#xff0c;系统专门提供了一组成为伪列(Pseudocolumn)的数据库列&#xff0c;这些列不是在建立对象时由我们完成的&#xff0c;而是在我们建立时由Oracle完成的。Oracle目前有以下伪列&#xff1a;一、伪列&#…

linux内核分为四个子系统,linux操作系统的内核有哪几个子系统构成,简要说明各子系统的作用...

Linux是一个一体化内核(monolithic kernel)系统。“内核”指的是一个提供硬件抽象层、磁盘及文件系统控制、多任务等功能的系统软件。一个内核不是一套完整的操作系统。一套基于Linux内核的完整操作系统叫作Linux操作系统&#xff0c;或是GNU/Linux。设备驱动程序可以完全访问硬…

linux运行搜狗拼音,Linux 搜狗输入法的安装(Ubuntu版)

1、首先从搜狗官网下载搜狗输入法Linux版本的安装包2、按ctrl alt T 打开Linux终端3、安装搜狗输入法&#xff1a; sudo dkpg -i xxx.deb, 如果报错&#xff0c;主要是由于两个原因&#xff1a;a、权限不够&#xff0c;可以通过获取root权限&#xff0c;命令‘su’&#xff1b;…

2023年腾讯云轻量应用服务器测评2核2G4M带宽

腾讯云轻量应用服务器测评2核2G4M带宽88元一年&#xff0c;2核CPU、2G内存、3M带宽&#xff0c;腾讯云轻量应用服务器&#xff08;Tencent Cloud Lighthouse&#xff09;是一款开箱即用的云服务器产品&#xff0c;面向轻量应用场景&#xff0c;旨在为中小企业和开发者提供便捷高…

linux 运行unix elf,在Linux中ELF可执行问题

我在Linux上有一些关于ELF可执行文件的奇怪问题.这是我的系统(uname -a)&#xff1a;Linux 3.16.0-4-amd64 #1 SMP Debian 3.16.7-ckt20-1deb8u2 (2016-01-02) x86_64 GNU/Linux我有以下程序(test.asm),我使用NASM组装它&#xff1a;; program just exits with code 0 using Li…