项目中实现的代码:

一.
//controller
@RequestMapping(value = "/exportAccountManager")
public void exportAccountManager(HttpServletRequest request, HttpServletResponse response,
@RequestParam String fileName, String orgNo, String consNo, String consName, Integer consState) {
String templateFileName = request.getSession().getServletContext().getRealPath("/") + "resources/templates/"
+ fileName;
try (InputStream input = new BufferedInputStream(new FileInputStream(templateFileName));
OutputStream output = response.getOutputStream();) {
Map<String, Object> params = buildParam(orgNo, consNo, consName, consState);
List<AccountManagerModel> dataList = accountManagerService.queryAccountManagerList(params);
CommonUtils.exportExcel(response, fileName, "客户清单.xls", input, output, dataList);
} catch (Throwable ex) {
LOGGER.error("导出客户清单失败:", ex);
}
} //参数
private Map<String, Object> buildParam(String orgNo, String consNo, String consName, Integer consState) {
Map<String, Object> params = new HashMap<String, Object>();
CommonUtils.addOrgParam(orgNo, commonService, params);
params.put("consNo", consNo);
params.put("consName", consName);
params.put("consState", consState);
return params;
}
二.工具类中导出相关
public static void exportExcel(HttpServletResponse response, String fileName, String cnFileName, InputStream input,
OutputStream output, List<?> dataList) throws IOException {
cnFileName = URLEncoder.encode(cnFileName, StandardCharsets.UTF_8.name());
response.setHeader("Content-Disposition", "attachment;filename=" + cnFileName);
response.setContentType("application/vnd.ms-excel");
Map<String, Object> params = new HashMap<String, Object>();
params.put("dataList", dataList);
exportExcel(input, output, params);
output.flush();
} public static void exportExcel(InputStream is, OutputStream os, Map<String, Object> params) throws IOException {
Context context = PoiTransformer.createInitialContext();
if (MapUtils.isNotEmpty(params)) {
Iterator<Map.Entry<String, Object>> iterator = params.entrySet().iterator();
while (iterator.hasNext()) {
Map.Entry<String, Object> entry = iterator.next();
context.putVar(entry.getKey(), entry.getValue());
}
}
JxlsHelper jxlsHelper = JxlsHelper.getInstance();
Transformer transformer = jxlsHelper.createTransformer(is, os);
JexlExpressionEvaluator evaluator = (JexlExpressionEvaluator) transformer.getTransformationConfig()
.getExpressionEvaluator();
evaluator.getJexlEngine().setSilent(true); // 设置静默模式,不报警告 // 函数强制,自定义功能
Map<String, Object> funcs = new HashMap<String, Object>();
funcs.put("utils", new JxlsUtils());
evaluator.getJexlEngine().setFunctions(funcs); // 必须要这个,否者表格函数统计会错乱
jxlsHelper.setUseFastFormulaProcessor(false).processTemplate(context, transformer);
} 三.service
@Override
public List<AccountManagerModel> queryAccountManagerList(Map<String, Object> params) throws Exception {
return accountManagerMapper.queryAccountManagerList(params);
} //service接口
public List<AccountManagerModel> queryAccountManagerList(Map<String, Object> params) throws Exception;
四.mapper
//mapper接口
public List<AccountManagerModel> queryAccountManagerList(Map<String, Object> params) throws Exception;
////mapper映射xml
<select id="queryAccountManagerList" parameterType="java.util.Map" resultMap="AccountManagerResultMap">
select
a.cons_id,
a.cons_no,
a.cons_name,
a.cons_address,
a.legal_person,
a.legal_person_phone,
a.bill_person,
a.bill_person_phone,
a.electric_person,
a.electric_person_phone,
a.entrusted_person,
a.entrusted_person_phone,
a.cons_state,
a.org_no,
b.org_name
from be_cons_info a, o_org b
where a.org_no = b.org_no
<if test="orgNo != null and orgNo != ''">
and FIND_IN_SET(a.org_no, #{orgNo})
</if>
<if test="consNo != null and consNo != ''">
and a.cons_no like concat('%', #{consNo}, '%')
</if>
<if test="consName != null and consName != ''">
and a.cons_name like concat('%', #{consName}, '%')
</if>
<if test="consState != null">
and a.cons_state = #{consState}
</if>
<if test="powerCompany != null and powerCompany != ''">
and b.org_name like concat('%', #{powerCompany}, '%')
</if>
</select>

五.前端Html

<div class="tool_wrapper">
<button class="ui-btn ui-btn-primary" onclick="addAccountManager();">新增</button>
<button class="ui-btn ui-btn-primary left20" onclick="editAccountManager();">修改</button>
<!-- <button class="ui-btn ui-btn-primary left20" onclick="cancelAccountManager();">注销</button> -->
<button class="ui-btn ui-btn-primary left20 fileinput-button">
<span>导入Excel</span>
<input id="fileupload" type="file" name="file" accept="application/vnd.ms-excel">
</button>
<button class="ui-btn ui-btn-primary left20" onclick="exportXls()">导出Excel</button>
<button class="ui-btn ui-btn-primary left20" onclick="downloadXlsTemplate()">下载模板</button>
</div>

六.js

function exportXls() {
var params = getSearchTableParams();
var url = getUrl("accountManager/exportAccountManager?fileName=cons.xls", params, true);
window.location.href = basePath + url;
}
/**
* 获取查询表格参数
* @returns Array
*/
function getSearchTableParams() {
var params = [];
$(".search_table input,.search_table select").each(function () {
var _this = $(this);
params.push({
name: _this.attr('name'),
value: _this.val()
});
});
return params;
} /**
* 获取URL
*
* @param url URL
* @param params URL参数
* @param urlContainParam URL是否包含参数,默认不含参数
* @returns
*/
function getUrl(url, params, urlContainParam) {
if (params == null || params.length == 0)
return url;
if (urlContainParam == null)
urlContainParam = false;
var arr = [url];
$(params).each(function (i, e) {
if (i == 0 && urlContainParam == false) {
arr.push("?" + e.name + "=" + e.value);
} else {
arr.push("&" + e.name + "=" + e.value);
}
});
return arr.join('');
}

Java实现导出Excel的更多相关文章

  1. 重构:以Java POI 导出EXCEL为例

    重构 开头先抛出几个问题吧,这几个问题也是<重构:改善既有代码的设计>这本书第2章的问题. 什么是重构? 为什么要重构? 什么时候要重构? 接下来就从这几个问题出发,通过这几个问题来系统的 ...

  2. java 实现导出Excel文件

    java 实现导出Excel(java生成 excel 并导出文件) 经常有有一些数据需要导出成   excel  格式 ,所以就需要实现啦 开始: 1.加入jar poi-3.6-20091214. ...

  3. java后端导出excel

    最近工作中需要导出excel.这次机智一点做个笔记,顺便写了一个比较通用的工具类.自然目前不能生成java实体类属性嵌套多次的这种没办法导出了,后续有需要的时候我再改改. 首先,java后端导出exc ...

  4. java:POI导出excel

    POI是一个开源项目,专用于java平台上操作MS OFFICE,企业应用开发中可用它方便导出Excel. 下面是使用示例: 1.maven中先添加依赖项 <dependency> < ...

  5. Java POI 导出EXCEL经典实现 Java导出Excel

    转自http://blog.csdn.net/evangel_z/article/details/7332535 在web开发中,有一个经典的功能,就是数据的导入导出.特别是数据的导出,在生产管理或者 ...

  6. java导入导出excel常用操作小结及简单示例

    POI中常用设置EXCEL的操作小结: 操作excel如下 HSSFWorkbook wb = new HSSFWorkbook();  //创建一个webbook,对应一个Excel文件 HSSFS ...

  7. [ExtJS5学习笔记]第三十四节 sencha extjs 5 grid表格之java后台导出excel

    继上次使用js前端导出excel之后,还有一个主要大家比较关注的是后台实现导出excel,因为本人开发使用的java所以这里使用apache的开源项目poi进行后台excel的导出. 本文目录 本文目 ...

  8. 重构:以Java POI 导出EXCEL为例2

    前言 上一篇博文已经将一些对象抽象成成员变量以及将一些代码块提炼成函数.这一节将会继续重构原有的代码,将一些函数抽象成类,增加成员变量,将传入的参数合成类等等. 上一篇博文地址:http://www. ...

  9. 【转载】Java导入导出excel

    转自:https://blog.csdn.net/jerehedu/article/details/45195359 目前,比较常用的实现Java导入.导出Excel的技术有两种Jakarta POI ...

  10. Java POI导出Excel不弹框选择下载路径(下载文件不选择下载路径,默认) Chrome

    在Chrome浏览器中,Java导出Excel文件时,浏览器弹出提示框,需要选择下载路径 在Chrome中的高级设置中,把“下载前询问每个文件的保存位置”去掉就解决了 DEEPLOVE(LC)

随机推荐

  1. 痞子衡嵌入式:在IAR开发环境下将关键函数重定向到RAM中执行的三种方法

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家分享的是在IAR开发环境下将关键函数重定向到RAM中执行的三种方法. 嵌入式项目里应用程序代码正常是放在 Flash 中执行的,但有时候也需要将 ...

  2. 在包一级定制log4j日志输出

    软件开发和维护过程中,日志是必不可少的工具,对于一个10万行规模的产品,要分析它的某一部分,最简单的方法是将log4j配置文件的rootLogger的输出级别设置为debug,但这样将使产品的所有部分 ...

  3. PXE高效批量装机

    目录 一.PXE概述 二.PXE的优点 三.搭建PXE的前提 四.搭建PXE远程安装服务器 4.1.安装并启用TFTP服务 4.2.安装dhcp服务 4.3.准备linux内核.初始化镜像文件 4.3 ...

  4. bootstrap导航条报错 Uncaught TypeError: Cannot convert object to primitive value

    原文: https://feiffy.cc/uncaught-typeerror-cannot-convert-object-to-primitive-value 最近发现我的博客页面移动端上下拉菜单 ...

  5. java 的内存结构

    Java内存结构详解 Java把内存分成:栈内存,堆内存,方法区,本地方法区和寄存器等. 下面分别介绍栈内存,堆内存,方法区各自一些特性: 1.栈内存 (1)一些基本类型的变量和对象的引用变量都是在函 ...

  6. 【mysql】mysql逻辑框架简介及show profile说明

    1.mysql逻辑框架简介 和其它数据库相比,MySQL 有点与众不同,它的架构可以在多种不同场景中应用并发挥良好作用.主要体现在存储引擎的架构上,插件式的存储引擎架构将查询处理和其它的系统任务以及数 ...

  7. 【mysql】mysql简介及高手是如何练成的

    1.什么是mysql  MySQL 是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于Oracle 公司. Mysql 是开源的,可以定制的,采用了GPL 协议,你可以修改源码 ...

  8. Swagger2.X注解

    常用到的注解有: 作用范围 API 使用位置 协议集描述 @Api 用于controller类上 协议描述 @ApiOperation 用在controller的方法上 非对象参数集 @ApiImpl ...

  9. 线程间协作的两种方式:wait、notify、notifyAll和Condition

    转载自海子: 在前面我们将了很多关于同步的问题,然而在现实中,需要线程之间的协作.比如说最经典的生产者-消费者模型:当队列满时,生产者需要等待队列有空间才能继续往里面放入商品,而在等待的期间内,生产者 ...

  10. Go版本管理--依赖包存储

    目录 1. 简介 2. GOPATH 依赖包存储 3.GOMODULE 依赖包存储 4.包名大小写敏感问题 1. 简介 GOPATH模式下,依赖包存储在$GOPATH/src,该目录下只保存特定依赖包 ...