java, poi, excel
工作需要用java操作Excel,现在网上搜索了一下,决定选取POI包来操作。pom内容如下:
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>3.8</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>3.8</version>
</dependency>
两个版本需要一致,否则会出错。
excel 03和07版本对应不同的操作类,分别是HSSFWorkbook和XSSFWorkbook。他们都继承自接口Workbook,所以在打开文件的时候,判断是哪一个版本,然后使用Workbook操作:
private static Workbook createWorkBook(String path) {
try {
InputStream in = new FileInputStream(path);
if (!in.markSupported()) {
in = new PushbackInputStream(in, 8);
}
if (POIFSFileSystem.hasPOIFSHeader(in)) {
return new HSSFWorkbook(in);
}
if (POIXMLDocument.hasOOXMLHeader(in)) {
return new XSSFWorkbook(OPCPackage.open(in));
}
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (InvalidFormatException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
throw new IllegalArgumentException("打开excel文件(" + path + ")错误");
}
相应的Sheet,Row 和 Cell也都使用最上层的接口类:
private static Sheet getSheetByName(Workbook workbook, String s) {
Sheet sheet = workbook.getSheet(s);
if (sheet == null)
sheet = workbook.createSheet(s);
return sheet;
}
private static Row getRowFromSheet(Sheet sheet, int rowNum) {
Row row;
row = sheet.getRow(rowNum);
if (row != null)
return row;
else {
row = sheet.createRow(rowNum);
return row;
}
}
以Sheet为例, workbook.getSheet(i)是获得第i个sheet表单,如果不存在,则返回空。 workbook.createSheet(i)是创建表单,会覆盖原有表单。
从Cell中读取数据,有时候使用poi读取出来的单元格式会和在excel中看到的不一样。所以在读取数据时需要多判断一下类型,在poi源码的基础上修改一下:
private static String handleCellV1(Cell cell, int type) { // 读取日期形式单元格数据,返回字符串数据
String var1 = null;
int cellType = cell.getCellType();
switch (cellType) {
case 0: // numeric
if (DateUtil.isCellDateFormatted(cell)) { // 如果是日期格式
SimpleDateFormat sdf = null;
if (type == 1) {
sdf = new SimpleDateFormat(DATE); // String DATE = "yyyy-MM-dd";
} else {
sdf = new SimpleDateFormat(TIME);
}
Date date = cell.getDateCellValue();
var1 = sdf.format(cell.getDateCellValue());
} else { // 有时候也会变成数字格式
String res = String.valueOf(cell.getNumericCellValue());
BigDecimal bd = new BigDecimal(res); // 数字格式在excel中都是double,所以需要去掉小数点后的数(直接int??)
res = bd.toPlainString();
String[] ss = res.split("\\.");
res = ss[0];
var1 = res;
}
break;
case 1: // text
var1 = cell.getStringCellValue();
break;
default: // #unknown cell type
var1 = "Unknown Cell Type: " + cell.getCellType();
var1 = null;
}
return var1;
}
写入excel单元格数据,可以使普通的写入:
Row row = sheet.createRow(rowNum);
row.createCell().setCellValue("日期");
也可以写入公式:
row.createCell().setCellFormula("IF(B" + rowNum + "=\"初始\",(SUMIFS(F:F,E:E,E" + rowNum + ",C:C,C" + rowNum + ",D:D,D" + rowNum + ",B:B,\"初始\")" +
"-SUMIFS(F:F,E:E,E" + rowNum + ",C:C,C" + rowNum + ",D:D,D" + rowNum + ",B:B,\"平\"))" +
"/COUNTIFS(E:E,E" + rowNum + ",C:C,C" + rowNum + ",D:D,D" + rowNum + ",B:B,B" + rowNum + "),IF(B" + rowNum + "=\"开\",F" + rowNum + ",F" + rowNum + "))");
写入公示后读取公式的结果摸索了一阵,网上有两种说法:
FormulaEvaluator evaluator = new XSSFFormulaEvaluator((XSSFWorkbook)workbook); CellValue cellValue = evaluator.evaluate(cell1); String res = cellValue.getStringValue();
try {
value = String.valueOf(cell.getNumericCellValue());
} catch (IllegalStateException e) {
value = String.valueOf(cell.getRichStringCellValue());
}
尝试了之后发现都不能正确读出来。
后来无意中发现,需要手动把写入公式的excel文件打开再保存一下,就可以正常读取。保存之后,在知道类型的情况下直接使用简单语句:
row.getCell(9).getNumericCellValue();
写入excel文件:
FileOutputStream fout = null;
Workbook workbook = null;// 创建工作薄
try {
workbook = createWorkBook(dir + filename);
// workbook = createWorkBook(dir+"test123.xlsx");
// workbook = new XSSFWorkbook();
Sheet sheet0 = getSheetByName(workbook, sheet1Name);
Sheet sheet1 = getSheetByName(workbook, sheet2Name);
// .... //
fout = new FileOutputStream(dir + filename);
// fout = new FileOutputStream(dir + "test123.xlsx");
workbook.write(fout);
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
if (fout != null) {
fout.close();
}
} catch (IOException e) {
e.printStackTrace();
}
}
java, poi, excel的更多相关文章
- java POI excel 导出复合样式(一个单元格两个字体)
前言:java poi 导出 excel 时,需要设置一个单元格有多个字体样式,有点类似于富文本. 想要达到的效果(一个单元格里): 我使用的 poi 版本是 <dependency> & ...
- java POi excel 写入大批量数据
直接贴代码: package jp.co.misumi.mdm.batch.common.jobrunner; import java.io.File; import java.io.FileNotF ...
- java poi excel 生成表格的工具封装
效果如下: 代码如下: import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import ...
- Java POI Excel 导入导出
这个东西很容易懂,不是特别难,难就难在一些复杂的计算和Excel格式的调整上. 近期写了一个小列子,放上来便于以后使用. POI.jar下载地址:http://mirror.bit.edu.cn/ap ...
- java POI Excel 单元格样式
正如Html需要CSS一样,我们的POI生成的Excel同样需要样式才能更完美的表现我们的数据.下面还是从简单的例子出发,学习和了解POI的样式设计. 一.我的位置. 1 package com.my ...
- java poi excel操作 下拉菜单 及数据有效性
1 private InputStream updateTemplateStyleHSSF(InputStream inputStream,CsCustCon csCustCon) throws IO ...
- java poi excel导入模板设置下拉框
import org.apache.poi.hssf.usermodel.DVConstraint; import org.apache.poi.hssf.usermodel.HSSFCell; im ...
- java poi Excel导入 整数浮点数转换问题解决
/** * 获取单元格数据 */ protected static String getCellValue(Cell cell) { String cellValu ...
- java poi excel操作 把第一列放到最后去
@Override public void adjustExcleColumnPosition(String filePath,int col) throws Exception{ File file ...
随机推荐
- WampServe修改默认网站目录的方法(转)
1wamp简介 WampServe集成了Apache.MySQL.PHP.phpmyadmin,支持Apache的mod_rewrite,PHP扩展.Apache模块只需要在菜单“开启/关闭”上点点就 ...
- .NET 强引用和弱引用
一:什么是弱引用 了解弱引用之前,先了解一下什么是强引用 例如 : Object obj=new Object(); 就是一个强引用,内存分配一份空间给用以存储Object数据,这块内存有一个 ...
- ibatis批量操作补充
ibatis批量操作 这文章的补充吧. review代码的时候发现一个页面应用排序设置功能,原先代码中,进行了循环update实现.虽然应用较少,不过无谓浪费数据库链接实在不是一个好的想法. 所以, ...
- JS几种table切换
1.使用className <!doctype html> <html lang="en"> <head> <meta charset=& ...
- 【 D3.js 入门系列 --- 2 】 如何使用数据和选择元素
接着上一讲的内容,这次讨论如何选择元素和使用数据. 现在页面中有三行文字,代码为: <p>Hello World 1</p> <p>Hello World 2 ...
- kernel/module.c
#include <linux/errno.h>#include <linux/kernel.h>#include <asm/segment.h>#include ...
- hdu4737 A Bit Fun ——O(n)做法、错误的做法 + 正确做法
囧== 下面的做法是错误的.下午在路上突然明白了== 哎,到现在还是只知道暴力的做法,囧爆了:http://www.cnblogs.com/liuxueyang/p/3322197.html 类似于前 ...
- Python 爬虫学习 网页图片下载
使用正则表达式匹配 # coding:utf-8 import re import urllib def get_content(url): """ Evilxr, &q ...
- Fortran学习心得
编译调试: 服务器上所用的编译器可以编译.F90的文件,同时,经过测试已经知道有两款编译器:gfortran和ifort. 另外,查看编译器的bash命令是:gfortran -v. 编程算法思想与C ...
- Visual Studio 启动修复命令
今天VS启动不了了,连命令行的 devenv.exe /? 都执行不了,看不到帮助命令了,记性不好,以前看过但没记住呀,还好我装了两个不同版本的VS, 另一个VS的帮助命令还是可以看到的.虽然修复了, ...