poi 技术动态更新 Excel模板内容,动态更新内容
1.控制器方法
private URL base = this.getClass().getResource("");
/**
* 流拍之后,可以下载询价单
*
* @param id 拍卖id
* @param response
*/
@RequestMapping(value="/inquiryDownLoad",method = RequestMethod.GET)
@ResponseBody
public void inquiryDownLoad(String aucId,HttpServletResponse response) {
//日志记录
if (logger.isDebugEnabled()) {
logger.debug("inquiryDownLoad, aucLotId ", aucId);
}
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
AucLot aucLot = aucLotRepository.findOne(aucId);
if(aucLot!=null){
SysUser sysUser=sysUserRepository.findOne(aucLot.crtUserId());
AucPrice aucPrice=aucPriceListService.findAucLotCurrentPrice(aucId);
try {
//获取模板文件的目录地址
String fileDir = new File(base.getFile(), "../../../../../../doc/").getCanonicalPath();
//获取模板文件
File demoFile=new File(fileDir + "/inquiryPrice.xls");
//这里传入一个空模板
FileInputStream in = new FileInputStream(demoFile);
//创建Excel的 JAVA 对象
HSSFWorkbook book = new HSSFWorkbook(in);
HSSFSheet sheet = book.getSheetAt(0);//获取Excel的第一页内容
sheet.protectSheet("123456");//设置Excel编辑密码,没有密码不可以编辑
HSSFRow row = null;
HSSFCell cell=null;
//动态更新特定坐标位置的值
//公司留存 拍卖开始时间
row=sheet.getRow(6);
cell=row.getCell(12);
cell.setCellValue(sdf.format(aucLot.startTime()));
//公司留存委托人姓名and手机号
row=sheet.getRow(9);
cell=row.getCell(11);
cell.setCellValue(aucLot.crtUserName());
row=sheet.getRow(11);
cell=row.getCell(11);
if(sysUser!=null && sysUser.mobile()!=null){
cell.setCellValue(sysUser.mobile().replace(sysUser.mobile().substring(3, 8), "****"));
}
//委托人留存
row=sheet.getRow(35);
cell=row.getCell(11);
cell.setCellValue(aucLot.crtUserName());
row=sheet.getRow(37);
cell=row.getCell(11);
if(sysUser!=null && sysUser.mobile()!=null){
cell.setCellValue(sysUser.mobile().replace(sysUser.mobile().substring(3, 8), "****"));
}
//拍品保留价and最高出价
row=sheet.getRow(21);
cell=row.getCell(29);
cell.setCellValue(aucLot.reservePrice().doubleValue());
row=sheet.getRow(22);
cell=row.getCell(29);
cell.setCellValue(aucPrice.price().doubleValue());
//设置下载题头
response.setContentType("application/xls");
String name = java.net.URLEncoder.encode(aucLot.goodsNo()+"测试.xls", "UTF8");
response.addHeader("Content-Disposition", "attachment; filename=" + name);
ByteArrayOutputStream ostream = new ByteArrayOutputStream();
ServletOutputStream servletOS = response.getOutputStream();
book.write(ostream);
servletOS.write(ostream.toByteArray());
servletOS.flush();
servletOS.close();
} catch (IOException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
}
}
poi 技术动态更新 Excel模板内容,动态更新内容的更多相关文章
- POI技术实现对excel的导出
需求:客户端传来两个参数,当前页码和每页的条数,根据传来的参数实现对数据的导出 1.导入依赖 <!-- 报表相关 --> <dependency> <groupId> ...
- 替换excel模板中的内容并使用JavaMail发送邮件
由于在公司工作,常年出差,每天都要以日报的形式向公司汇报当天的工作内容.而日报的内容大体上就只有当天工作的主要内容时变化的,其余的都是不变 的. 而我的电脑刚打开excel有点卡,因此决定使用Java ...
- poi读取Excel模板并修改模板内容与动态的增加行
有时候我们可能遇到相当复杂的excel,比如表头的合并等操作,一种简单的方式就是直接代码合并(浪费时间),另一种就是写好模板,动态的向模板中增加行和修改指定单元格数据. 1.一个简单的根据模板shee ...
- 利用POI 技术动态替换word模板内容
项目中需要实现一个功能,动态替换给定模板里面的内容,生成word文档提供下载功能. 中间解决了问题有: 1.页眉的文档logo图片解决,刚开始的时候,HWPFDocument 对象无法读取图片对象(已 ...
- java的poi技术下载Excel模板上传Excel读取Excel中内容(SSM框架)
使用到的jar包 JSP: client.jsp <%@ page language="java" contentType="text/html; charset= ...
- Excel模板导出之动态导出
说明 目前Magicodes.IE已支持Excel模板导出时使用JObject.Dictionary和ExpandoObject来进行动态导出,具体使用请看本篇教程. 本功能的想法.部分实现初步源于a ...
- poi读取excel模板,填充内容并导出,支持导出2007支持公式自动计算
/** * 版权所有(C) 2016 * @author www.xiongge.club * @date 2016-12-7 上午10:03:29 */ package xlsx; /** * @C ...
- POI根据EXCEL模板,修改内容导出新EXCEL (只支持HSSF)
package excelPoiTest; import java.io.File; import java.io.FileInputStream; import java.io.FileOutput ...
- MFC编辑框接收数据动态更新与刷新方法代码示例-如何让编辑框内容实时更新
MFC编辑框接收数据动态更新与刷新方法代码示例-如何让编辑框内容实时更新 关键代码: //发送数据通知 //from txwtech@163.com LRESULT CCommSampleDlg::O ...
随机推荐
- 响应式之像素和viewport
引言 按照pc尺寸做好的网页,在手机端打开,看起来像是pc的缩小版,东西都在只是字太小都看不清了,有什么办法放大呢? 于是去google一下,发现,贴了这么一行代码就轻松解决了: <meta n ...
- 【58沈剑架构系列】lvs为何不能完全替代DNS轮询
上一篇文章“一分钟了解负载均衡的一切”引起了不少同学的关注,评论中大家争论的比较多的一个技术点是接入层负载均衡技术,部分同学持这样的观点: 1)nginx前端加入lvs和keepalived可以替代“ ...
- AC日记——#2057. 「TJOI / HEOI2016」游戏 LOJ
#2057. 「TJOI / HEOI2016」游戏 思路: 最大流: 代码: #include <cstdio> #include <cstring> #include &l ...
- AC日记——小A和uim之大逃离 II 洛谷七月月赛
小A和uim之大逃离 II 思路: spfa: 代码: #include <bits/stdc++.h> using namespace std; #define INF 0x3f3f3f ...
- day2、购物商城
作业:购物商城 商品展示,价格 买,加入购物车 付款,钱不够 代码如下: import codecs #登录接口,用户名密码都正确登录成功,否则失败 def login(your_name,your_ ...
- express中间件的理解
参考 :https://blog.csdn.net/huang100qi/article/details/80220012 Express中间件分为三种内置中间件.自定义中间件.第三方中间件 可以与n ...
- MYSQL注入天书之前言
写在前面的一些内容 请允许我叨叨一顿: 最初看到sqli-labs也是好几年之前了,那时候玩了前面的几个关卡,就没有继续下去了.最近因某个需求想起了sqli-labs,所以翻出来玩了下.从每一关卡的娱 ...
- Python中的模块(2)
1.内置模块2.扩展的 例如:django3.自定义的 文件import demodef read(): print('my read func')demo.read()print(demo.mone ...
- CF336B[思维题]
题目链接[http://codeforces.com/problemset/problem/336/B] 题意:画出2*m个圆圈,编号为1-m的圆圈在同一行相邻,编号在m+1-2*m的圆圈在同一行,有 ...
- luoguP3317 [SDOI2014]重建 变元矩阵树定理 + 概率
首先,我们需要求的是 $$\sum\limits_{Tree} \prod\limits_{E \in Tree} E(u, v) \prod\limits_{E \notin Tree} (1 - ...