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模板内容,动态更新内容的更多相关文章

  1. POI技术实现对excel的导出

    需求:客户端传来两个参数,当前页码和每页的条数,根据传来的参数实现对数据的导出 1.导入依赖 <!-- 报表相关 --> <dependency> <groupId> ...

  2. 替换excel模板中的内容并使用JavaMail发送邮件

    由于在公司工作,常年出差,每天都要以日报的形式向公司汇报当天的工作内容.而日报的内容大体上就只有当天工作的主要内容时变化的,其余的都是不变 的. 而我的电脑刚打开excel有点卡,因此决定使用Java ...

  3. poi读取Excel模板并修改模板内容与动态的增加行

    有时候我们可能遇到相当复杂的excel,比如表头的合并等操作,一种简单的方式就是直接代码合并(浪费时间),另一种就是写好模板,动态的向模板中增加行和修改指定单元格数据. 1.一个简单的根据模板shee ...

  4. 利用POI 技术动态替换word模板内容

    项目中需要实现一个功能,动态替换给定模板里面的内容,生成word文档提供下载功能. 中间解决了问题有: 1.页眉的文档logo图片解决,刚开始的时候,HWPFDocument 对象无法读取图片对象(已 ...

  5. java的poi技术下载Excel模板上传Excel读取Excel中内容(SSM框架)

    使用到的jar包 JSP: client.jsp <%@ page language="java" contentType="text/html; charset= ...

  6. Excel模板导出之动态导出

    说明 目前Magicodes.IE已支持Excel模板导出时使用JObject.Dictionary和ExpandoObject来进行动态导出,具体使用请看本篇教程. 本功能的想法.部分实现初步源于a ...

  7. poi读取excel模板,填充内容并导出,支持导出2007支持公式自动计算

    /** * 版权所有(C) 2016 * @author www.xiongge.club * @date 2016-12-7 上午10:03:29 */ package xlsx; /** * @C ...

  8. POI根据EXCEL模板,修改内容导出新EXCEL (只支持HSSF)

    package excelPoiTest; import java.io.File; import java.io.FileInputStream; import java.io.FileOutput ...

  9. MFC编辑框接收数据动态更新与刷新方法代码示例-如何让编辑框内容实时更新

    MFC编辑框接收数据动态更新与刷新方法代码示例-如何让编辑框内容实时更新 关键代码: //发送数据通知 //from txwtech@163.com LRESULT CCommSampleDlg::O ...

随机推荐

  1. Geoffrey Hinton获得IEEE的麦克斯韦奖的颁奖辞

    2016年6月IEEE的麦克斯韦奖颁发给了机器学习的领军人物Geoffrey Hinton.颁奖辞十分优雅,同时简洁.凝练地解释了机器学习的最新进展以及神经网络的崛起.我忍不住翻译了一下. 颁奖辞 G ...

  2. NIO-5补充

    import java.io.IOException; import java.nio.ByteBuffer; import java.nio.channels.FileChannel; import ...

  3. SGU 209. Areas

    209. Areas time limit per test: 0.25 sec.memory limit per test: 65536 KB input: standardoutput: stan ...

  4. DotNetOpenAuth实践系列

    写在前面 本人在研究DotNetOpenAuth的过程中,遇到很多问题,很多坑,花费了很多时间才调通这玩意,现在毫无保留的分享出来,希望博友们可以轻松的上手DotNetOpenAuth,减少爬坑时间. ...

  5. 易普优APS 5.0高级计划排程系统助力工业4.0智能工厂建设

    (一)智能工厂建设核心 <中国制造2025>明确提出要推进制造过程智能化,智能工厂是实现智能制造的重要载体.作为智能工厂,在生产过程应实现自动化.透明化.可视化.精益化的同时,产品检测.质 ...

  6. 【ASP.NET MVC】Scripts目录

    很多时候我们经常在用的东西我们可能不一定真正的了解,因为我们可能已经会用了,便不再对其进行探索,下面我们看一下在ASP.NET MVC3项目下的Scripts目录下的文件: Jquery核心库我们就不 ...

  7. ZXing.Net.Mobile无法识别较大的条码

    ZXing.Net.Mobile无法识别较大的条码 在Xamarin项目中,使用ZXing.Net.Mobile实现条码扫描时,可能会出现无法顺利识别较大的条码,而可以正常识别较小的条码.这是由于ZX ...

  8. bzoj 2055: 80人环游世界 -- 上下界网络流

    2055: 80人环游世界 Time Limit: 10 Sec  Memory Limit: 64 MB Description     想必大家都看过成龙大哥的<80天环游世界>,里面 ...

  9. php上传文件常见问题(基础)

    既然上一篇文章<php上传中文文件文件名乱码问题>遇到了文件上传的问题,干脆把php上传文件时经常碰到的几个问题总结一下吧,以后用到时不用再去找了. 1.先做个最简单的上传文件 <h ...

  10. Codeforces Beta Round #9 (Div. 2 Only) B. Running Student 水题

    B. Running Student 题目连接: http://www.codeforces.com/contest/9/problem/B Description And again a misfo ...