/**

* 导出excel

* @param request

* @param response

* @return

* @throws Exception

*/

@RequestMapping("exportExcel")

@Action(description="导出excel")

public void exportExcel(HttpServletRequest request, HttpServletResponse response) throws Exception

{

//获取实体类,并取得时刻点的值,存放到map里面

String  id = RequestUtil.getString(request,"id");

LoadDate ld = new LoadDate();

ld = loadDateService.getById(Long.parseLong(id));

String mapVal = ld.getValue();

JSONObject json = JSONObject.fromObject(mapVal);

Map<String,String> map = new HashMap<String,String>();

if (BeanUtils.isNotEmpty(json)) {

Iterator<String> iterator = json.keys();

while (iterator.hasNext()) {

String ie = (String) iterator.next();

map.put(ie, json.getString(ie));

}

}

String dirPath = FileUtil.getRootPath() + File.separator+"commons" +File.separator+"template"+File.separator+"exportMode"+File.separator;

String fileName="loadTemplate.xls";

FileInputStream inStream = new FileInputStream(new File(dirPath+fileName));

//读取excel模板

HSSFWorkbook wb = new HSSFWorkbook(inStream);    //读取excel模板

//读取了模板内所有sheet内容

HSSFSheet sheet = wb.getSheetAt(0);

HSSFCell cell = null;

//在相应的单元格进行赋值

for(int i=2;i<=97;i++){

cell = sheet.getRow(i).getCell(1);

String tmp = cell.getStringCellValue();

cell.setCellValue(map.get(tmp));

}

for(int i=98;i<=102;i++){

cell = sheet.getRow(i).getCell(1);

String tmp = cell.getStringCellValue();

if("ycgfdl".equals(tmp)){

if(BeanUtils.isNotEmpty(ld.getYcgfdl())){

cell.setCellValue(ld.getYcgfdl());

}else{

cell.setCellValue("");

}

}else if("ycqdl".equals(tmp)){

if(BeanUtils.isNotEmpty(ld.getYcqdl())){

cell.setCellValue(ld.getYcqdl());

}else{

cell.setCellValue("");

}

}else if("yccfdLi".equals(tmp)){

if(BeanUtils.isNotEmpty(ld.getYccfdLi())){

cell.setCellValue(ld.getYccfdLi());

}else{

cell.setCellValue("");

}

}else if("yccfdLl".equals(tmp)){

if(BeanUtils.isNotEmpty(ld.getYccfdLl())){

cell.setCellValue(ld.getYccfdLl());

}else{

cell.setCellValue("");

}

}else if("ycdgdl".equals(tmp)){

if(BeanUtils.isNotEmpty(ld.getYcdgdl())){

cell.setCellValue(ld.getYcdgdl());

}else{

cell.setCellValue("");

}

}

}

response.setContentType("application/octet-stream;charset=UTF-8");

response.setHeader("Content-Type","application/vnd.ms-excel");

response.setHeader( "Content-Disposition", "attachment;filename=" + new String( fileName.getBytes("GB2312"), "8859_1" ));

response.addHeader("Pargam", "no-cache");

response.addHeader("Cache-Control", "no-cache");

OutputStream out = response.getOutputStream();

wb.write(out);

out.flush();

out.close();

}

poi 实战代码---导出Excel(根据模板导出)的更多相关文章

  1. POI实现导出Excel和模板导出Excel

    一.导出过程 1.用户请求导出 2.先访问数据库,查询需要导出的结果集 3.创建导出的Excel工作簿 4.遍历结果集,写入工作簿 5.将Excel已文件下载的形式回复给请求客户端 二.具体实现(截取 ...

  2. JXLS导出Excel(模板导出)

    1.导包 在pom.xml中加入依赖如下: <dependency> <groupId>org.jxls</groupId> <artifactId>j ...

  3. C# 使用Epplus导出Excel [2]:导出动态列数据

    C# 使用Epplus导出Excel [1]:导出固定列数据 C# 使用Epplus导出Excel [2]:导出动态列数据 C# 使用Epplus导出Excel [3]:合并列连续相同数据 C# 使用 ...

  4. C# 使用Epplus导出Excel [1]:导出固定列数据

    C# 使用Epplus导出Excel [1]:导出固定列数据 C# 使用Epplus导出Excel [2]:导出动态列数据 C# 使用Epplus导出Excel [3]:合并列连续相同数据 C# 使用 ...

  5. Access中一句查询代码实现Excel数据导入导出

    摘 要:用一句查询代码,写到vba中实现Excel数据导入导出,也可把引号中的SQL语句直接放到查询分析器中执行正 文: 导入数据(导入数据时第一行必须是字段名): DoCmd.RunSQL &quo ...

  6. Html Table用JS导出excel格式问题 导出EXCEL后单元格里的000412341234会变成412341234 7-14 会变成 2018-7-14(7月14) 自定义格式 web利用table表格生成excel格式问题 js导出excel增加表头、mso-number-format定义数据格式 数字输出格式转换 mso-number-format:"\@"

    Html Table用JS导出excel格式问题 我在网上找的JS把HTML Tabel导出成EXCEL.但是如果Table里的数字内容为0开的的导成Excel后会自动删除0,我想以text的格式写入 ...

  7. Powerdesigner 导出Excel格式数据字典 导出Excel格式文件

    版权声明:本文为博主原创文章,转载请注明出处; 网上我也看到了很多的Powerdesigner 导出方法,因为Powerdesigner 提供了部分VBA功能,所以让我用代码导出Excel格式文件得以 ...

  8. JAVA 导出 Excel, JS 导出 Excel

    本介绍两种Excle导出方法: JAVA 导出 Excle, JS 导出 Excle 1, js 根据 html 页面的 table > tr > td 标签导出 js代码: //导出 v ...

  9. C# NPOI导出Excel和EPPlus导出Excel比较

    系统中经常会使用导出Excel的功能. 之前使用的是NPOI,但是导出数据行数多就报内存溢出. 最近看到EPPlus可以用来导出Excel,就自己测了下两者导出上的差异. NPIO官网地址:http: ...

随机推荐

  1. 通信原理之IP协议,ARP协议 (三)

    把这三个协议放到一起学习是因为这三个协议处于同一层,ARP协议用来找到目标主机的Ethernet网卡Mac地址,IP则承载要发送的消息.数据链路层可以从ARP得到数据的传送信息,而从IP得到要传输的数 ...

  2. mysql5.5 报Can't open and lock privilege tables: Table 'mysql.host' doesn't exist

    通过yum 的webstatic源安装的mysql55w-server,然后用service mysqld start启动时报 MySQL Daemon failed to start.Startin ...

  3. WPS 2019 多个sheet表拆分成独立的excel文件

    参考: https://www.cnblogs.com/hackxiyu/p/8945975.html 场景:将多个sheet表拆分成独立的excel文件 一.安装VB工具: 默认情况下:wps -- ...

  4. perl 读取一个文件 替换文件的关键词 把数据替换到新的文件

    replace # replace #!/usr/bin/perl my @data = (); my ($fname ,$rp, $nfname)= @ARGV; my ($o, $n) = spl ...

  5. 正则表达式、re模块

    正则表达式 一说规则我已经知道你很晕了,现在就让我们先来看一些实际的应用.在线测试工具 http://tool.chinaz.com/regex/ 正则表达式是用来匹配字符串非常强大的工具,在其他编程 ...

  6. poj3613 Cow Relays【好题】【最短路】【快速幂】

    Cow Relays Time Limit: 1000MS   Memory Limit: 65536K Total Submissions:9207   Accepted: 3604 Descrip ...

  7. NPOI 自定义单元格背景颜色 XSSFWorkbook - Excel

    x 网上找到了,HSSFWorkbook自定义颜色的例子(讲的还挺细致的),但是XSSFWorkbook确没找到...研究了一下,坑掉了一地... NPOI.XSSF.UserModel.XSSFWo ...

  8. jdbc --- javabean

    第一部分: javaBean 类  要和数据库表的字段一一对应 package com.ljs.bean; public class UserBean { private int id; privat ...

  9. Codeforces 219C - Color Stripe - [DP]

    题目链接:http://codeforces.com/problemset/problem/219/C 题意: 给你 $n$ 个方块排成水平一排,每个方块都涂上 $k$ 种颜色中的一种.要求对尽量少的 ...

  10. tensorRT使用python进行网络定义