POI读取单元格信息及单元格公式
Java操作EXCEL的利器一般都是POI和JXL,鄙人只是POI的忠实粉丝。(其实我是没有用过JXL)。
现在大多数的excel都是07以上的版本,所以我一般是用07的基础上使用POI。
- 一、读取单元格
单元格有样式和值,以及值得类型。
样式复制封装成一个函数:
public XSSFCellStyle cloneAllCellStyle(XSSFCell sourceCell, XSSFWorkbook targetWb){
//创建一个样式
XSSFCellStyle tempStyle = targetWb.createCellStyle(); //样式
//数值格式,创建字符及数字格式
DataFormat format= targetWb.createDataFormat();
//字体
XSSFFont font= targetWb.createFont();
try{
tempStyle.setDataFormat(format.getFormat( sourceCell.getCellStyle().getDataFormatString()));
}catch(NullPointerException e){
tempStyle.setDataFormat((short)0);
}
font.setColor(sourceCell.getCellStyle().getFont().getXSSFColor());
font.setBold(sourceCell.getCellStyle().getFont().getBold());
font.setBoldweight(sourceCell.getCellStyle().getFont().getBoldweight());
try{
font.setCharSet(sourceCell.getCellStyle().getFont().getCharSet());
}catch(POIXMLException e){
font.setCharSet(0);
}
// font.setCharSet(sourceCell.getCellStyle().getFont().getCharSet());
font.setFamily(sourceCell.getCellStyle().getFont().getFamily());
font.setFontHeight(sourceCell.getCellStyle().getFont().getFontHeight());
font.setFontHeightInPoints(sourceCell.getCellStyle().getFont().getFontHeightInPoints());
font.setFontName(sourceCell.getCellStyle().getFont().getFontName());
font.setItalic(sourceCell.getCellStyle().getFont().getItalic());
font.setStrikeout(sourceCell.getCellStyle().getFont().getStrikeout());
// font.setThemeColor(sourceCell.getCellStyle().getFont().getThemeColor());
font.setTypeOffset(sourceCell.getCellStyle().getFont().getTypeOffset());
font.setUnderline(sourceCell.getCellStyle().getFont().getUnderline());
tempStyle.setAlignment( sourceCell.getCellStyle().getAlignment());
tempStyle.setVerticalAlignment(sourceCell.getCellStyle().getVerticalAlignment());
tempStyle.setBorderBottom(sourceCell.getCellStyle().getBorderBottom());
tempStyle.setBorderLeft(sourceCell.getCellStyle().getBorderLeft());
tempStyle.setBorderRight(sourceCell.getCellStyle().getBorderRight());
tempStyle.setBorderTop(sourceCell.getCellStyle().getBorderTop());
tempStyle.setBottomBorderColor(sourceCell.getCellStyle().getBottomBorderXSSFColor());
tempStyle.setLeftBorderColor(sourceCell.getCellStyle().getLeftBorderXSSFColor());
tempStyle.setRightBorderColor(sourceCell.getCellStyle().getRightBorderXSSFColor());
tempStyle.setTopBorderColor(sourceCell.getCellStyle().getTopBorderXSSFColor());
tempStyle.setFillBackgroundColor(sourceCell.getCellStyle().getFillBackgroundColorColor());
tempStyle.setFont(font);
try{
tempStyle.setFillForegroundColor(sourceCell.getCellStyle().getFillForegroundColorColor());
}catch(NullPointerException e){
tempStyle.setFillForegroundColor(IndexedColors.WHITE.getIndex());
}
tempStyle.setFillPattern(sourceCell.getCellStyle().getFillPattern());
tempStyle.setRotation(sourceCell.getCellStyle().getRotation());
tempStyle.setHidden(sourceCell.getCellStyle().getHidden());
tempStyle.setWrapText(sourceCell.getCellStyle().getWrapText());
tempStyle.setIndention(sourceCell.getCellStyle().getIndention());
tempStyle.setLocked(sourceCell.getCellStyle().getLocked());
return tempStyle;
}
调用直接获取单元格的样式内容。
获取单元格值的类型:cell.getCellType()
根据值类型不同获取不同的值:
switch (cell.getCellType()) {
case Cell.CELL_TYPE_BLANK:
tempValue.add("");
break;
case Cell.CELL_TYPE_BOOLEAN:
tempValue.add(cell.getBooleanCellValue());
break;
case Cell.CELL_TYPE_ERROR:
tempValue.add(cell.getErrorCellString());
break;
case Cell.CELL_TYPE_FORMULA:
tempValue.add(cell.getCellFormula());
map.put("formulaFlag", true);
break;
case Cell.CELL_TYPE_NUMERIC:
tempValue.add(cell.getNumericCellValue());
break;
case Cell.CELL_TYPE_STRING:
tempValue.add(cell.getStringCellValue());
break;
default:
break;
}
创建内容
//工作空间
XSSFWorkbook targetWb = new XSSFWorkbook();
//sheet
XSSFSheet targetSheet = targetWb.createSheet("行汇总");
// 删除sheet
targetWb.removeSheetAt(index); //index表示第几个sheet,从0开始计数
//row
XSSFRow row=targetSheet.createRow(i+num1-startRow+1);
//cell
XSSFCell cell=row.createCell(j); //j 行
二、 操作单元格函数
POI能够读取函数,然后再把函数写入到单元格中,excel自己计算函数。而函数操作单元格的位置,一般是固定的,所以操作的单元格无法改变。
1、读取函数和写入函数
cell.getCellFormula()
上面的代码中,获取函数的内容,类型为string。
写入函数:
cell.setCellFormula((String)cellValues.get(j));
2、获取函数计算之后的值:
有的地方直接写:
cell.getNumberValue();这样有时候会报错,当cell的内容不是值得时候。
最后做一个异常抛出。
当然有时候也读不出值,读出的值是0.0(double)
读取函数值得另一种方法:
XSSFFormulaEvaluator evaluator=new XSSFFormulaEvaluator(targetWb);
CellValue tempCellValue = evaluator.evaluate(cell);
double cellValue1 =
tempCellValue.getNumberValue();
如何你是获取excel的值之后,再写入另一个单元格,建议写入值之前,先改变单元的值类型,变成数值型:
cell.set(XSSFCell.CELL_TYPE_NUMERIC);
POI读取单元格信息及单元格公式的更多相关文章
- poi 读取word 遍历表格和单元格中的图片
背景 项目需要解析word表格 需要批量导入系统,并保存每行信息到数据库 并且要保存word中的图片, 并保持每条信息和图片的对应关系 一行数据可能有多条图片 解决办法 没有找到现成的代码,怎么办呐? ...
- poi读取合并单元格
poi读取合并单元格 学习了:http://blog.csdn.net/ycb1689/article/details/9764191 进行了列合并单元格的修正:原来是我自己找错了地方: import ...
- 无法读取Excel中的数据单元格。有数据,但是读出来全是空值
C#读取Excel,取值为空的解决办法! C#读取Excel遇到无法读取的解决方法是什么呢?这样在C#读取Excel的过程中有很多问题,那么本文就向你介绍如何解决C#读取Excel遇到无法读取的解决方 ...
- POI按照源单元格设置目标单元格格式
原文:http://jjw198874.blog.163.com/blog/static/1889845522011102401854234/ POI按照源单元格设置目标单元格格式 poi按照一个源单 ...
- 读取Excel文件中的单元格的内容和颜色
怎样读取Excel文件中的单元格的内容和颜色 先创建一个Excel文件,在A1和A2中随意输入内容,设置A1的字体颜色为红色,A2的背景为黄色.需要 using Excel = Microsoft.O ...
- .net读取Excel转datatable、.net读取的Excel存在合并单元格并且转成datatable
项目中经常会遇到Excel导入数据,Excel的模板会可能是存在合并单元格的,模板如下图所示 读取时需要填充合并单元格的值,转成datatable单元格值时,填充合并单元格的值,如下图所示: 合并单元 ...
- 使用poi调整字体格式、添加单元格注释、自动调整列宽
1 创建新的工作铺 import java.io.FileOutputStream; import org.apache.poi.hssf.usermodel.HSSFCell; import org ...
- excel小技巧-用于测试用例的编号栏:“获取当前单元格的上一格的值+1”=INDIRECT(ADDRESS(ROW()-1,COLUMN()))+1
编写用例的时候使用,经常修改用例的时候会需要增加.删除.修改条目,如果用下拉更新数值的方式会很麻烦. 1.使用ctrl下拉,增删移动用例的时候,需要每次都去拉,万一列表比较长,会很麻烦 2.使用ROW ...
- 用NPOI创建Excel、合并单元格、设置单元格样式、边框的方法
本篇文章小编为大家介绍,用NPOI创建Excel.合并单元格.设置单元格样式.边框的方法.需要的朋友参考下 今天在做项目中,遇到使用代码生成具有一定样式的Excel,找了很多资料,最后终于解决了,Ex ...
随机推荐
- DB常见问题排查方法
一般情况下,系统多多少少都会遇到点问题,那么遇到问题之后我们怎么定位原因呢?在这里我只说如何定位DB的问题. 看这篇文章有个前提:监控数据要完整!监控数据要完整!!监控数据要完整!!!比如下面这个乍一 ...
- 八、阻塞等待异步结果FutureTask
一.简介 默认的异步任务有些难以控制,有时候我们希望在当前线程获取异步任务的结果.FutureTask可以帮助我们实现 JDK文档:http://tool.oschina.net/uploads/ap ...
- groovy闭包科里化参数
科里化闭包:带有预先绑定形参的闭包.在预先绑定一个形参之后,调用闭包时就不必为这个形参提供实参了.有助于去掉方法调用中的冗余重复. 使用curry方法科里化任意多个参数 使用rcurry方法科里化后面 ...
- golang label breaks
我们在for多层嵌套时,有时候需要直接跳出所有嵌套循环, 这时候就可以用到go的label breaks特征了. 先看一个范例代码: package main import ( "f ...
- java ThreadLocal(应用场景及使用方式及原理)
尽管ThreadLocal与并发问题相关,可是很多程序猿只将它作为一种用于"方便传參"的工具,胖哥觉得这或许并非ThreadLocal设计的目的,它本身是为线程安全和某些特定场景的 ...
- HDU-2046 骨牌铺方格【递推】
http://acm.hdu.edu.cn/showproblem.php?pid=2046 和前面的一样,a[i] = a[i-1] + a[i-2] #include<iostream> ...
- Visual studio 2013打开报异常"Exception has been thrown by the target of an invocation"
最近遇到一个问题,打开VS2013和SQL Server2014都会出报错,错误信息如下: 以前都是好好的,重启了机子也不行,能打开两个VS,再打开第三个VS还是会报错,百度无果,还是在google上 ...
- DOM基础操作(一)
DOM的基本操作有四种,我们会逐一给大家进行展示 增加操作 1.创建元素节点 createElement 我们可以通过document.createElement(‘div’);这个方法来创建一个元素 ...
- Freebsd10.3(FreeBSD11 Beta1)使用手记
Freebsd10.3(FreeBSD11 Beta1)使用手记 1.安装系统. 2.设置ssh2登录,并开启ftp. (1)编辑/etc/ssh/sshd_config文件,设置如下: Permit ...
- Child extends Parent,可以得到什么?
如果有Child extends Parent 1.子类可以调用父类无参的构造函数,子类的有参构造函数和是否调用父类的有参数的构造函数无必然联系 2.接口继承的时候,只能继承接口不能继承类,因为如果类 ...