JAVA用POI读取和创建2003和2007版本Excel
1.添加maven依赖
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>3.10-FINAL</version>
</dependency>
2.读取和创建2003和2007版本Excel示例
package com.wyg.simple; import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.text.DecimalFormat;
import java.text.SimpleDateFormat;
import java.util.LinkedList;
import java.util.List; import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFDataFormat;
import org.apache.poi.hssf.usermodel.HSSFDateUtil;
import org.apache.poi.hssf.usermodel.HSSFFont;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.hssf.util.HSSFColor;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.CellStyle;
import org.apache.poi.ss.usermodel.Font;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.usermodel.XSSFCell;
import org.apache.poi.xssf.usermodel.XSSFWorkbook; public class CreatAndReadExcel {
private static String excel2007Path = "D:\\temp\\style_2007.xlsx";
private static String excel2003Path = "D:\\temp\\style_2003.xls"; public static void main(String[] args) throws Exception {
creatExcel(excel2007Path, "2007");// 创建2007版Excel文件
creatExcel(excel2003Path,"2003");// 创建2003版Excel文件 // List<List<Object>> excel2007List = readExcel(excel2007Path);// 读取2007版Excel文件
List<List<Object>> excel2003List = readExcel(excel2003Path);// 读取2003版Excel文件
System.out.println(excel2003List.toString());
} /**
* 创建Excel文件
*
* @return
* @throws IOException
*/
public static void creatExcel(String excelPath, String version) throws IOException {
// XSSFWork used for .xslx (>=2007), HSSWorkbook for 03 .xsl
Workbook workbook = null;
if (version.equals("2007")) {
workbook = new XSSFWorkbook();// 创建 一个excel文档对象
} else if (version.equals("2003")) {
workbook = new HSSFWorkbook();// 创建 一个excel文档对象
}
Sheet sheet = workbook.createSheet("2007sheet");// 创建一个工作薄对象
sheet.setColumnWidth(1, 10000);// 设置第二列的宽度为 Row row0 = sheet.createRow(1);// 创建一个行对象,从0行开始
row0.setHeightInPoints(23);// 设置行高23像素
for (int i = 0; i < 11; i++) {
Cell cell_1 = row0.createCell(i, Cell.CELL_TYPE_STRING);// 创建单元格,从0列开始
cell_1.setCellValue("column" + i);// 写入单元格的值
CellStyle style = getStyle(workbook);
cell_1.setCellStyle(style);// 应用样式对象
sheet.autoSizeColumn(i);// 自动调整列宽
} FileOutputStream outputStream = new FileOutputStream(excelPath);
workbook.write(outputStream);// 将文档对象写入文件输出流 outputStream.close();// 关闭文件输出流
System.out.println("创建成功 office excel");
} /**
* 设置样式
*
* @param workbook
* @return
*/
private static CellStyle getStyle(Workbook workbook) {
CellStyle style = workbook.createCellStyle();// 创建样式对象
// 设置对齐方式
style.setAlignment(HSSFCellStyle.ALIGN_CENTER_SELECTION);// 水平居中
style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);// 垂直居中 // 设置边框
style.setBorderTop(HSSFCellStyle.BORDER_THICK);// 顶部边框粗线
style.setTopBorderColor(HSSFColor.RED.index);// 设置为红色
style.setBorderBottom(HSSFCellStyle.BORDER_DOUBLE);// 底部边框双线
style.setBorderLeft(HSSFCellStyle.BORDER_MEDIUM);// 左边边框
style.setBorderRight(HSSFCellStyle.BORDER_MEDIUM);// 右边边框 style.setWrapText(true);// 设置单元格内容是否自动换行
// 格式化日期
style.setDataFormat(HSSFDataFormat.getBuiltinFormat("m/d/yy h:mm")); // 设置单元格字体
Font font = workbook.createFont(); // 创建字体对象
font.setFontHeightInPoints((short) 14);// 设置字体大小
font.setColor(HSSFColor.RED.index);// 设置字体颜色
font.setFontName("宋体");// 设置为宋体字
font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);// 设置粗体
style.setFont(font);// 将字体加入到样式对象 return style;
} /**
* 读取excel
*
* @param fileName
* @return 行<列>
* @throws IOException
*/ private static List<List<Object>> readExcel(String fileName) throws IOException {
File file = new File(fileName);
Workbook wb = null;
if (fileName.endsWith(".xlsx")) {//
wb = new XSSFWorkbook(new FileInputStream(file));// 创建 一个excel文档对象
} else if (fileName.endsWith(".xls")) {//
wb = new HSSFWorkbook(new FileInputStream(file));// 创建 一个excel文档对象
} Sheet sheet = wb.getSheetAt(0);// 读取第一个sheet页表格内容
Object value = null;
Row row = null;
Cell cell = null;
System.out.println("读取office 2007 excel内容如下:");
// System.out.println(sheet.getPhysicalNumberOfRows());// 获取的是物理行数,也就是不包括那些空行(隔行)的情况。
// System.out.println(sheet.getLastRowNum());// 获取的是最后一行的编号(编号从0开始)
// 行
List<List<Object>> rowlist = new LinkedList<List<Object>>();
for (int i = sheet.getFirstRowNum(); i <= sheet.getLastRowNum(); i++) {
row = sheet.getRow(i);
if (row == null) {
continue;
} // 列
List<Object> cellList = new LinkedList<Object>();
for (int j = row.getFirstCellNum(); j <= row.getLastCellNum(); j++) {
cell = row.getCell(j);
if (cell == null) {
continue;
} DecimalFormat df = new DecimalFormat("0");// 格式化 number String
DecimalFormat nf = new DecimalFormat("0.00");// 格式化数字
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");// 格式化日期字符串
switch (cell.getCellType()) {
case XSSFCell.CELL_TYPE_STRING:// 字符串——String type
value = cell.getStringCellValue();
break;
case XSSFCell.CELL_TYPE_NUMERIC:// 数字——Number type
if ("@".equals(cell.getCellStyle().getDataFormatString())) {
value = df.format(cell.getNumericCellValue());
} else if ("General".equals(cell.getCellStyle().getDataFormatString())) {
value = nf.format(cell.getNumericCellValue());
} else {
value = sdf.format(HSSFDateUtil.getJavaDate(cell.getNumericCellValue()));
}
break;
case XSSFCell.CELL_TYPE_BOOLEAN:// boolean——Boolean type
value = cell.getBooleanCellValue();
break;
case XSSFCell.CELL_TYPE_BLANK:// 空白——Blank type
value = "";
break;
default:// default type
value = cell.toString();
}
if (value == null || "".equals(value)) {
continue;
}
cellList.add(value);
}
rowlist.add(cellList);
}
return rowlist;
}
}
JAVA用POI读取和创建2003和2007版本Excel的更多相关文章
- JAVA用POI读取和创建2003和2007版本Excel完美示例
import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import ja ...
- Java之POI读取Excel的Package should contain a content type part [M1.13]] with root cause异常问题解决
Java之POI读取Excel的Package should contain a content type part [M1.13]] with root cause异常问题解决 引言: 在Java中 ...
- JAVA使用POI读取EXCEL文件的简单model
一.JAVA使用POI读取EXCEL文件的简单model 1.所需要的jar commons-codec-1.10.jarcommons-logging-1.2.jarjunit-4.12.jarlo ...
- Java使用POI读取和写入Excel指南
Java使用POI读取和写入Excel指南 做项目时经常有通过程序读取Excel数据,或是创建新的Excel并写入数据的需求: 网上很多经验教程里使用的POI版本都比较老了,一些API在新版里已经废弃 ...
- POI 读取word (word 2003 和 word 2007)(转,好用)
POI 读取word (word 2003 和 word 2007)(转,好用) 转做的操作: 将作者文中失效的链接的正确链接放在失效链接的下面. 最近在给客户做系统的时候,用户提出需求,要能够导入 ...
- java使用poi读取ppt文件和poi读取excel、word示例
java使用poi读取ppt文件和poi读取excel.word示例 http://www.jb51.net/article/48092.htm
- java使用poi读取doc和docx文件(maven自动导入依赖包)
java使用poi读取doc和docx文件(maven自动导入依赖包) 于是在网上搜寻了一阵之后才发现原来doc文档和excel一样不能用普通的io流的方法来读取,而是也需要用poi,于是进行了一番尝 ...
- java使用poi读取word(简单,简约,直观)
java使用poi读取word(简单,简约,直观) 说明 其实poi的官网上面都是有接口和样例的,只是都是英文 例如网址:http://poi.apache.org/spreadsheet/quick ...
- 【Java POI】POI基于事件驱动解析大数据量2007版本Excel,空值导致列错位问题
1.目前测试了20M的文件,可以读取. 2.支持单个工作表1万+的数据行数,耗时如图. 3.以下是关键地方处理的代码 //Accepts objects needed while parsing. / ...
随机推荐
- Linux(CentOS6.7) 安装MySql5.7数据库 图文教程
linux(CentOS6.7) 环境Mysql 5.7.17安装教程分享给大家,供大家参考,具体内容如下: 1系统约定安装文件下载目录:/data/softwareMysql目录安装位置:/usr/ ...
- Fiddler进行模拟POST、PUT提交数据注意点
1.请求头要加 Accept: application/xml Content-Type: application/json 2.地址栏url地址后不要忘记加“/” 3.POST和PUT的对象参数都是 ...
- 图论:Floyd-多源最短路、无向图最小环
在最短路问题中,如果我们面对的是稠密图(十分稠密的那种,比如说全连接图),计算多源最短路的时候,Floyd算法才能充分发挥它的优势,彻彻底底打败SPFA和Dijkstra 在别的最短路问题中都不推荐使 ...
- HUST 1103 校赛 邻接表-拓扑排序
Description N students were invited to attend a party, every student has some friends, only if someo ...
- outer的使用
outer就是一个标签,java语言中根本没有此关键字,因此outer也可以用其它的词来代替 java中的标签就是一个紧跟着英文冒号(:)的标识符.与其他语言不同的是,java中的标签只有放在循环语言 ...
- 【BZOJ4821】【SDOI2017】相关分析 [线段树]
相关分析 Time Limit: 10 Sec Memory Limit: 128 MB[Submit][Status][Discuss] Description Frank对天文学非常感兴趣,他经 ...
- PACM Team(牛客第三场多校赛+dp+卡内存+打印路径)
题目链接(貌似未报名的不能进去):https://www.nowcoder.com/acm/contest/141/A 题目: 题意:背包题意,并打印路径. 思路:正常背包思路,不过五维的dp很容易爆 ...
- hdu 1070 Milk(贪心)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1070 Milk Time Limit: 2000/1000 MS (Java/Others) M ...
- 在ubuntu16.04+python3.5情况下安装nltk,以及gensim时pip3安装不成功的解决办法
在ubuntu16.04+python3.5情况下安装nltk,以及gensim时pip3安装不成功的解决办法,我刚开始因为不太会用linux命令,所以一直依赖于python 的pip命令,可是怎么都 ...
- Python第三方库matplotlib(2D绘图库)入门与进阶
Matplotlib 一 简介: 二 相关文档: 三 入门与进阶案例 1- 简单图形绘制 2- figure的简单使用 3- 设置坐标轴 4- 设置legend图例 5- 添加注解和绘制点以及在图形上 ...