POI SXSSFWorkbook 读取模板 存在公式解决
- package com.baoqilai.base.service.export;
- import java.io.File;
- import java.io.FileInputStream;
- import java.util.HashMap;
- import java.util.Iterator;
- import java.util.List;
- import java.util.Map;
- import org.apache.poi.ss.usermodel.Cell;
- import org.apache.poi.ss.usermodel.CellStyle;
- import org.apache.poi.ss.usermodel.DataFormat;
- import org.apache.poi.ss.usermodel.Row;
- import org.apache.poi.ss.usermodel.Sheet;
- import org.apache.poi.xssf.streaming.SXSSFSheet;
- import org.apache.poi.xssf.streaming.SXSSFWorkbook;
- import org.apache.poi.xssf.usermodel.XSSFWorkbook;
- import com.baoqilai.ddg.util.ExcelUtil;
- import com.baoqilai.scp.exception.BaseException;
- import com.baoqilai.scp.service.export.ExcelExportService;
- import com.baoqilai.scp.service.export.ExcelExportStragy;
- /**
- * 模板导出
- * @author lly
- *
- */
- public class TemplateExportServiceImpl implements ExcelExportService {
- /**
- * 模板地址
- */
- protected String tempAddress;
- /**
- * 模板结果集
- */
- protected String[] result;
- public TemplateExportServiceImpl(String tempAddress, String[] result) {
- super();
- this.tempAddress = tempAddress;
- this.result = result;
- }
- @Override
- public SXSSFWorkbook export(List<Map<String, Object>> data) throws BaseException {
- long stime = System.currentTimeMillis();
- try {
- File fi = new File(tempAddress);
- FileInputStream is = new FileInputStream(fi);
- XSSFWorkbook wb = new XSSFWorkbook(is);
- //获取模板中最后一行,用于判断是否存在公式
- int lastRowNum = wb.getSheetAt(0).getLastRowNum();
- Sheet sheet0 = wb.getSheetAt(0);
- Row baseRow0=sheet0.getRow(2);
- lastRowNum = wb.getSheetAt(0).getLastRowNum();
- Map<Integer, String> gsMap=new HashMap<>();
- for (Iterator<Cell> it = baseRow0.cellIterator(); it.hasNext();) {
- Cell baseCell = it.next();
- if (baseCell.getCellType() == Cell.CELL_TYPE_FORMULA) {
- String cellFormula = baseCell.getCellFormula();
- gsMap.put(baseCell.getColumnIndex(), cellFormula);
- }
- }
- sheet0.removeRow(baseRow0); //取到公式后进行删除
- SXSSFWorkbook workbook = new SXSSFWorkbook(wb, 500);
- Sheet sheet = workbook.getSheetAt(0);
- CellStyle contextstyle = workbook.createCellStyle();
- DataFormat df = workbook.createDataFormat();
- contextstyle.setDataFormat(df.getFormat("#,##0.00"));
- final int startRow = lastRowNum;
- for (int i = startRow; i < data.size() + startRow; i++) {
- int rowNum = i - startRow;
- Row row = sheet.getRow(i);
- if (row == null) {
- row = sheet.createRow(i);
- }
- Map<String, Object> dataMap = data.get(rowNum);
- String[] columNames = result;
- dataMap.put("serialNum", rowNum + 1);
- for (int j = 0; j < columNames.length; j++) {
- Cell cell = row.getCell(j);
- if (cell == null) {
- cell = row.createCell(j);
- }
- System.out.println(cell.getColumnIndex());
- Object val = dataMap.get(columNames[j]);
- ExcelUtil.setCellValue(cell, val, contextstyle);
- if(gsMap.get(cell.getColumnIndex())!=null){
- String cellFormula =gsMap.get(cell.getColumnIndex());
- String s = cellFormula.replaceAll("(\\w)\\d", "$1" + (i + 1));
- cell.setCellFormula(s);
- cell.setCellType(Cell.CELL_TYPE_FORMULA);
- }
- }
- dataMap.clear();
- // 清空内存中缓存的行数
- if (i % 500 == 0) {
- ((SXSSFSheet) sheet).flushRows();
- }
- }
- // 数据清理
- data.clear();
- data = null;
- workbook.setForceFormulaRecalculation(true);//计算公式
- long etime = System.currentTimeMillis();
- System.out.println("处理写入模板数据用时:" + (etime - stime) / 1000);
- return workbook;
- } catch (Exception e) {
- e.printStackTrace();
- }
- return null;
- }
- @Override
- public SXSSFWorkbook exportByStragegy(List<Map<String, Object>> data, ExcelExportStragy stragegy)
- throws BaseException {
- long stime = System.currentTimeMillis();
- long etime = System.currentTimeMillis();
- System.out.println("处理写入模板数据用时:" + (etime - stime) / 1000);
- return null;
- }
- }
POI SXSSFWorkbook 读取模板 存在公式解决的更多相关文章
- java操作Excel之POI(5)利用POI实现使用模板批量导出数据
后台导出方法: 在源文件夹src下面放个准备好的模板:/com/cy/template/userExportTemplate.xls,这个模板有头部一行: /** * 后台导出方法 * 利用POI实现 ...
- poi导入读取时间格式问题
万能处理方案: 所有日期格式都可以通过getDataFormat()值来判断 yyyy-MM-dd-----14 yyyy年m月d日--- 31 yyyy年m月-------57 m月d日 ---- ...
- java的poi技术读取Excel数据到MySQL
这篇blog是介绍java中的poi技术读取Excel数据,然后保存到MySQL数据中. 你也可以在 : java的poi技术读取和导入Excel了解到写入Excel的方法信息 使用JXL技术可以在 ...
- java的poi技术读取Excel[2003-2007,2010]
这篇blog主要是讲述java中poi读取excel,而excel的版本包括:2003-2007和2010两个版本, 即excel的后缀名为:xls和xlsx. 读取excel和MySQL相关: ja ...
- Brophp框架开发时连接数据库读取UTF8乱码的解决(转)
Brophp框架开发时连接数据库读取UTF8乱码的解决办法 (2012-09-15 10:41:22) 转载▼ 标签: 杂谈 it php 分类: 建站技术 Brophp框架开发时连接数据库读取UTF ...
- vxworks for x86读取bios时间的解决方法
vxworks for x86读取bios时间的解决方法 系统时间与bsp有关,在vzworks for x86系列的目标没有直接读取RTC(实时时钟控制器)的函数,用time.h中的函数读到的始终是 ...
- java利用poi来读取execl表格返回对象
利用poi来读取execl表格,返回一个对象(可能有点不完善,但是应该能满足平常的所用),用到了反射等等; 使用的jar包有: commons-collections4-4.1.jar poi-3.1 ...
- java的poi技术读取和导入Excel实例
本篇文章主要介绍了java的poi技术读取和导入Excel实例,报表输出是Java应用开发中经常涉及的内容,有需要的可以了解一下. 报表输出是Java应用开发中经常涉及的内容,而一般的报表往往缺乏通用 ...
- org.in2bits.MyXls.XlsDocument 生成excel文件 ; 如果想读取模板再另外生成的话,试试 NPOI
优点:不依赖Microsoft组件,在内存中操作excel,读写速度快. 缺点:无法读取模板,只能生成新的excel (我亲自测试是在读取完模板后,不能保存,也不能另存,并且其他人说这个读取还会有 ...
随机推荐
- Reachability实时监控网络变化
Reachability是一种实时观察网络发生变化控件,如当你的手机处于WiFi情况下,他就会检测环境,当处于GPS的情况下改变环境,当处于无网络的情况下又是一种环境.下面我们看下关于Reachabi ...
- Vue自学笔记--项目的创建
一.项目的创建 1.必须要安装nodejs 2.搭建vue的开发环境 ,安装vue的脚手架工具 官方命令行工具 npm install --global vue-cli / ...
- 字符串String的API
字符串的理解 1. 字符串的属性 str.length 2. 字符串的方法 charAt() charCodeAt() indexOf() lastIndexOf() slice() substr ...
- TP5 自定义验证器
TP内置验证功能提供两种验证方法 验证器(推荐) $validate = Validate::make([ 'id' => 'require|integer', ]); if ($validat ...
- Django之form模板的使用
form模块的简介与用处 1.form 是前后端交互的一种方式, form表单提交的一种,django中有一个模块是form他主要用处就过滤前端form提交的数据 1. forms 模块是处理前后台的 ...
- 深度学习原理与框架-Tfrecord数据集的读取与训练(代码) 1.tf.train.batch(获取batch图片) 2.tf.image.resize_image_with_crop_or_pad(图片压缩) 3.tf.train.per_image_stand..(图片标准化) 4.tf.train.string_input_producer(字符串入队列) 5.tf.TFRecord(读
1.tf.train.batch(image, batch_size=batch_size, num_threads=1) # 获取一个batch的数据 参数说明:image表示输入图片,batch_ ...
- 用python优雅打开文件及上下文管理协议
有次面试被问到如何优雅地打开一个文件? 那就是用with语句,调用过后可以自动关闭. 但是为什么使用with语句就可以自动关闭呢,原因就是上下文管理协议. 上下文管理协议:包含方法 __e ...
- c++冒号作用
转自http://www.360doc.com/content/13/0605/11/3373961_290615318.shtml 1.冒号(:)用法 (1)表示机构内位域的定义(即该变量占几个bi ...
- python调用webservice接口
使用suds这个第三方模块 from suds.client import Clienturl = 'http://ip:port/?wsdl'cilent=Client(url)print cile ...
- linux下安装python,Django,虚拟环境
linux下python安装步骤: 1.下载python3源码包 wget https://www.python.org/ftp/python/3.6.6/Python-3.6.7.tgz 2.下载p ...