自己的包poi操作Excel工具
在前面的文章《使用poi读写Excel》中分享了一下poi操作Excel的简单演示样例。这次要分享一下我封装的一个Excel操作的工具类。
该工具类主要完毕的功能是:读取Excel、汇总Excel的功能。
在读取时。能够设定開始和结束读取的位置、设定是否读取多个sheet、设定读取那个或者那些sheet等。在汇总时,如设定是否覆盖目标文件、设定是否比較检查反复内容、设定检查反复的列索引等功能。详细来演示一下吧:
工具类源代码:
package com.tgb.ccl.excel.util; import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List; import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.CellStyle;
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.ss.util.CellRangeAddress;
import org.apache.poi.xssf.usermodel.XSSFWorkbook; /**
* Excel文件操作工具类,包含读、写、合并等功能
*
* @author : 龙轩
* @group : tgb8
* @Version : 1.00
* @Date : 2014-10-29 上午12:40:44
*/
public class ExcelUtil { //%%%%%%%%-------常量部分 開始----------%%%%%%%%%
/**
* 默认的開始读取的行位置为第一行(索引值为0)
*/
private final static int READ_START_POS = 0; /**
* 默认结束读取的行位置为最后一行(索引值=0。用负数来表示倒数第n行)
*/
private final static int READ_END_POS = 0; /**
* 默认Excel内容的開始比較列位置为第一列(索引值为0)
*/
private final static int COMPARE_POS = 0; /**
* 默认多文件合并的时须要做内容比較(同样的内容不反复出现)
*/
private final static boolean NEED_COMPARE = true; /**
* 默认多文件合并的新文件遇到名称反复时,进行覆盖
*/
private final static boolean NEED_OVERWRITE = true; /**
* 默认仅仅操作一个sheet
*/
private final static boolean ONLY_ONE_SHEET = true; /**
* 默认读取第一个sheet中(仅仅有当ONLY_ONE_SHEET = true时有效)
*/
private final static int SELECTED_SHEET = 0; /**
* 默认从第一个sheet開始读取(索引值为0)
*/
private final static int READ_START_SHEET= 0; /**
* 默认在最后一个sheet结束读取(索引值=0。用负数来表示倒数第n行)
*/
private final static int READ_END_SHEET = 0; /**
* 默认打印各种信息
*/
private final static boolean PRINT_MSG = true; //%%%%%%%%-------常量部分 结束----------%%%%%%%%% //%%%%%%%%-------字段部分 開始----------%%%%%%%%%
/**
* Excel文件路径
*/
private String excelPath = "data.xlsx"; /**
* 设定開始读取的位置,默觉得0
*/
private int startReadPos = READ_START_POS; /**
* 设定结束读取的位置。默觉得0,用负数来表示倒数第n行
*/
private int endReadPos = READ_END_POS; /**
* 设定開始比較的列位置,默觉得0
*/
private int comparePos = COMPARE_POS; /**
* 设定汇总的文件是否须要替换。默觉得true
*/
private boolean isOverWrite = NEED_OVERWRITE; /**
* 设定是否须要比較,默觉得true(仅当不覆写目标内容是有效,即isOverWrite=false时有效)
*/
private boolean isNeedCompare = NEED_COMPARE; /**
* 设定是否仅仅操作第一个sheet
*/
private boolean onlyReadOneSheet = ONLY_ONE_SHEET; /**
* 设定操作的sheet在索引值
*/
private int selectedSheetIdx =SELECTED_SHEET; /**
* 设定操作的sheet的名称
*/
private String selectedSheetName = ""; /**
* 设定開始读取的sheet,默觉得0
*/
private int startSheetIdx = READ_START_SHEET; /**
* 设定结束读取的sheet,默觉得0,用负数来表示倒数第n行
*/
private int endSheetIdx = READ_END_SHEET; /**
* 设定是否打印消息
*/
private boolean printMsg = PRINT_MSG; //%%%%%%%%-------字段部分 结束----------%%%%%%%%% public static void main(String[] args) {
ExcelUtil eu = new ExcelUtil(); //从第一行開始读取
eu.setStartReadPos(1); String src_xlspath = "D:\\2.xls";
String dist_xlsPath = "D:\\1.xls";
List<Row> rowList;
try {
rowList = eu.readExcel(src_xlspath);
//eu.writeExcel_xls(rowList, src_xlspath, dist_xlsPath);
} catch (IOException e) {
e.printStackTrace();
}
} public ExcelUtil(){ } public ExcelUtil(String excelPath){
this.excelPath = excelPath;
} /**
* 还原设定(事实上是又一次new一个新的对象并返回)
* @return
*/
public ExcelUtil RestoreSettings(){
ExcelUtil instance = new ExcelUtil(this.excelPath);
return instance;
} /**
* 自己主动依据文件扩展名,调用相应的读取方法
*
* @Title: writeExcel
* @Date : 2014-9-11 下午01:50:38
* @param xlsPath
* @throws IOException
*/
public List<Row> readExcel() throws IOException{
return readExcel(this.excelPath);
} /**
* 自己主动依据文件扩展名,调用相应的读取方法
*
* @Title: writeExcel
* @Date : 2014-9-11 下午01:50:38
* @param xlsPath
* @throws IOException
*/
public List<Row> readExcel(String xlsPath) throws IOException{ //扩展名为空时,
if (xlsPath.equals("")){
throw new IOException("文件路径不能为空!");
}else{
File file = new File(xlsPath);
if(!file.exists()){
throw new IOException("文件不存在。");
}
} //获取扩展名
String ext = xlsPath.substring(xlsPath.lastIndexOf(".")+1); try { if("xls".equals(ext)){ //使用xls方式读取
return readExcel_xls(xlsPath);
}else if("xls".equals(ext)){ //使用xlsx方式读取
return readExcel_xlsx(xlsPath);
}else{ //依次尝试xls、xlsx方式读取
out("您要操作的文件没有扩展名。正在尝试以xls方式读取...");
try{
return readExcel_xls(xlsPath);
} catch (IOException e1) {
out("尝试以xls方式读取,结果失败。,正在尝试以xlsx方式读取...");
try{
return readExcel_xlsx(xlsPath);
} catch (IOException e2) {
out("尝试以xls方式读取。结果失败。\n请您确保您的文件是Excel文件,而且无损。然后再试。");
throw e2;
}
}
}
} catch (IOException e) {
throw e;
}
} /**
* 自己主动依据文件扩展名,调用相应的写入方法
*
* @Title: writeExcel
* @Date : 2014-9-11 下午01:50:38
* @param rowList
* @throws IOException
*/
public void writeExcel(List<Row> rowList) throws IOException{
writeExcel(rowList,excelPath);
} /**
* 自己主动依据文件扩展名,调用相应的写入方法
*
* @Title: writeExcel
* @Date : 2014-9-11 下午01:50:38
* @param rowList
* @param xlsPath
* @throws IOException
*/
public void writeExcel(List<Row> rowList, String xlsPath) throws IOException { //扩展名为空时,
if (xlsPath.equals("")){
throw new IOException("文件路径不能为空! ");
} //获取扩展名
String ext = xlsPath.substring(xlsPath.lastIndexOf(".")+1); try { if("xls".equals(ext)){ //使用xls方式写入
writeExcel_xls(rowList,xlsPath);
}else if("xls".equals(ext)){ //使用xlsx方式写入
writeExcel_xlsx(rowList,xlsPath);
}else{ //依次尝试xls、xlsx方式写入
out("您要操作的文件没有扩展名,正在尝试以xls方式写入...");
try{
writeExcel_xls(rowList,xlsPath);
} catch (IOException e1) {
out("尝试以xls方式写入,结果失败!,正在尝试以xlsx方式读取...");
try{
writeExcel_xlsx(rowList,xlsPath);
} catch (IOException e2) {
out("尝试以xls方式写入,结果失败! \n请您确保您的文件是Excel文件。而且无损,然后再试。");
throw e2;
}
}
}
} catch (IOException e) {
throw e;
}
} /**
* 改动Excel(97-03版,xls格式)
*
* @Title: writeExcel_xls
* @Date : 2014-9-11 下午01:50:38
* @param rowList
* @param dist_xlsPath
* @throws IOException
*/
public void writeExcel_xls(List<Row> rowList, String dist_xlsPath) throws IOException {
writeExcel_xls(rowList, excelPath,dist_xlsPath);
} /**
* 改动Excel(97-03版。xls格式)
*
* @Title: writeExcel_xls
* @Date : 2014-9-11 下午01:50:38
* @param rowList
* @param src_xlsPath
* @param dist_xlsPath
* @throws IOException
*/
public void writeExcel_xls(List<Row> rowList, String src_xlsPath, String dist_xlsPath) throws IOException { // 推断文件路径是否为空
if (dist_xlsPath == null || dist_xlsPath.equals("")) {
out("文件路径不能为空");
throw new IOException("文件路径不能为空");
}
// 推断文件路径是否为空
if (src_xlsPath == null || src_xlsPath.equals("")) {
out("文件路径不能为空");
throw new IOException("文件路径不能为空");
} // 推断列表是否有数据,假设没有数据。则返回
if (rowList == null || rowList.size() == 0) {
out("文档为空");
return;
} try {
HSSFWorkbook wb = null; // 推断文件是否存在
File file = new File(dist_xlsPath);
if (file.exists()) {
// 假设复写,则删除后
if (isOverWrite) {
file.delete();
// 假设文件不存在。则创建一个新的Excel
// wb = new HSSFWorkbook();
// wb.createSheet("Sheet1");
wb = new HSSFWorkbook(new FileInputStream(src_xlsPath));
} else {
// 假设文件存在。则读取Excel
wb = new HSSFWorkbook(new FileInputStream(file));
}
} else {
// 假设文件不存在,则创建一个新的Excel
// wb = new HSSFWorkbook();
// wb.createSheet("Sheet1");
wb = new HSSFWorkbook(new FileInputStream(src_xlsPath));
} // 将rowlist的内容写到Excel中
writeExcel(wb, rowList, dist_xlsPath); } catch (IOException e) {
e.printStackTrace();
}
} /**
* 改动Excel(97-03版。xls格式)
*
* @Title: writeExcel_xls
* @Date : 2014-9-11 下午01:50:38
* @param rowList
* @param dist_xlsPath
* @throws IOException
*/
public void writeExcel_xlsx(List<Row> rowList, String dist_xlsPath) throws IOException {
writeExcel_xls(rowList, excelPath , dist_xlsPath);
} /**
* 改动Excel(2007版,xlsx格式)
*
* @Title: writeExcel_xlsx
* @Date : 2014-9-11 下午01:50:38
* @param rowList
* @param xlsPath
* @throws IOException
*/
public void writeExcel_xlsx(List<Row> rowList, String src_xlsPath, String dist_xlsPath) throws IOException { // 推断文件路径是否为空
if (dist_xlsPath == null || dist_xlsPath.equals("")) {
out("文件路径不能为空");
throw new IOException("文件路径不能为空");
}
// 推断文件路径是否为空
if (src_xlsPath == null || src_xlsPath.equals("")) {
out("文件路径不能为空");
throw new IOException("文件路径不能为空");
} // 推断列表是否有数据,假设没有数据,则返回
if (rowList == null || rowList.size() == 0) {
out("文档为空");
return;
} try {
// 读取文档
XSSFWorkbook wb = null; // 推断文件是否存在
File file = new File(dist_xlsPath);
if (file.exists()) {
// 假设复写,则删除后
if (isOverWrite) {
file.delete();
// 假设文件不存在,则创建一个新的Excel
// wb = new XSSFWorkbook();
// wb.createSheet("Sheet1");
wb = new XSSFWorkbook(new FileInputStream(src_xlsPath));
} else {
// 假设文件存在,则读取Excel
wb = new XSSFWorkbook(new FileInputStream(file));
}
} else {
// 假设文件不存在,则创建一个新的Excel
// wb = new XSSFWorkbook();
// wb.createSheet("Sheet1");
wb = new XSSFWorkbook(new FileInputStream(src_xlsPath));
}
// 将rowlist的内容加入到Excel中
writeExcel(wb, rowList, dist_xlsPath); } catch (IOException e) {
e.printStackTrace();
}
} /**
* //读取Excel 2007版。xlsx格式
*
* @Title: readExcel_xlsx
* @Date : 2014-9-11 上午11:43:11
* @return
* @throws IOException
*/
public List<Row> readExcel_xlsx() throws IOException {
return readExcel_xlsx(excelPath);
} /**
* //读取Excel 2007版,xlsx格式
*
* @Title: readExcel_xlsx
* @Date : 2014-9-11 上午11:43:11
* @return
* @throws Exception
*/
public List<Row> readExcel_xlsx(String xlsPath) throws IOException {
// 推断文件是否存在
File file = new File(xlsPath);
if (!file.exists()) {
throw new IOException("文件名称为" + file.getName() + "Excel文件不存在!");
} XSSFWorkbook wb = null;
List<Row> rowList = new ArrayList<Row>();
try {
FileInputStream fis = new FileInputStream(file);
// 去读Excel
wb = new XSSFWorkbook(fis); // 读取Excel 2007版,xlsx格式
rowList = readExcel(wb); } catch (IOException e) {
e.printStackTrace();
}
return rowList;
} /***
* 读取Excel(97-03版。xls格式)
*
* @throws IOException
*
* @Title: readExcel
* @Date : 2014-9-11 上午09:53:21
*/
public List<Row> readExcel_xls() throws IOException {
return readExcel_xls(excelPath);
} /***
* 读取Excel(97-03版,xls格式)
*
* @throws Exception
*
* @Title: readExcel
* @Date : 2014-9-11 上午09:53:21
*/
public List<Row> readExcel_xls(String xlsPath) throws IOException { // 推断文件是否存在
File file = new File(xlsPath);
if (!file.exists()) {
throw new IOException("文件名称为" + file.getName() + "Excel文件不存在! ");
} HSSFWorkbook wb = null;// 用于Workbook级的操作,创建、删除Excel
List<Row> rowList = new ArrayList<Row>(); try {
// 读取Excel
wb = new HSSFWorkbook(new FileInputStream(file)); // 读取Excel 97-03版,xls格式
rowList = readExcel(wb); } catch (IOException e) {
e.printStackTrace();
}
return rowList;
} /***
* 读取单元格的值
*
* @Title: getCellValue
* @Date : 2014-9-11 上午10:52:07
* @param cell
* @return
*/
private String getCellValue(Cell cell) {
Object result = "";
if (cell != null) {
switch (cell.getCellType()) {
case Cell.CELL_TYPE_STRING:
result = cell.getStringCellValue();
break;
case Cell.CELL_TYPE_NUMERIC:
result = cell.getNumericCellValue();
break;
case Cell.CELL_TYPE_BOOLEAN:
result = cell.getBooleanCellValue();
break;
case Cell.CELL_TYPE_FORMULA:
result = cell.getCellFormula();
break;
case Cell.CELL_TYPE_ERROR:
result = cell.getErrorCellValue();
break;
case Cell.CELL_TYPE_BLANK:
break;
default:
break;
}
}
return result.toString();
} /**
* 通用读取Excel
*
* @Title: readExcel
* @Date : 2014-9-11 上午11:26:53
* @param wb
* @return
*/
private List<Row> readExcel(Workbook wb) {
List<Row> rowList = new ArrayList<Row>(); int sheetCount = 1;//须要操作的sheet数量 Sheet sheet = null;
if(onlyReadOneSheet){ //仅仅操作一个sheet
// 获取设定操作的sheet(假设设定了名称,按名称查,否则按索引值查)
sheet =selectedSheetName.equals("")? wb.getSheetAt(selectedSheetIdx):wb.getSheet(selectedSheetName);
}else{ //操作多个sheet
sheetCount = wb.getNumberOfSheets();//获取能够操作的总数量
} // 获取sheet数目
for(int t=startSheetIdx; t<sheetCount+endSheetIdx;t++){
// 获取设定操作的sheet
if(!onlyReadOneSheet) {
sheet =wb.getSheetAt(t);
} //获取最后行号
int lastRowNum = sheet.getLastRowNum(); if(lastRowNum>0){ //假设>0。表示有数据
out("\n開始读取名为【"+sheet.getSheetName()+"】的内容:");
} Row row = null;
// 循环读取
for (int i = startReadPos; i <= lastRowNum + endReadPos; i++) {
row = sheet.getRow(i);
if (row != null) {
rowList.add(row);
out("第"+(i+1)+"行:",false);
// 获取每一单元格的值
for (int j = 0; j < row.getLastCellNum(); j++) {
String value = getCellValue(row.getCell(j));
if (!value.equals("")) {
out(value + " | ",false);
}
}
out("");
}
}
}
return rowList;
} /**
* 改动Excel。并另存为
*
* @Title: WriteExcel
* @Date : 2014-9-11 下午01:33:59
* @param wb
* @param rowList
* @param xlsPath
*/
private void writeExcel(Workbook wb, List<Row> rowList, String xlsPath) { if (wb == null) {
out("操作文档不能为空!");
return;
} Sheet sheet = wb.getSheetAt(0);// 改动第一个sheet中的值 // 假设每次重写。那么则从開始读取的位置写,否则果获取源文件最新的行。 int lastRowNum = isOverWrite ? startReadPos : sheet.getLastRowNum() + 1;
int t = 0;//记录最新加入的行数
out("要加入的数据总条数为:"+rowList.size());
for (Row row : rowList) {
if (row == null) continue;
// 推断是否已经存在该数据
int pos = findInExcel(sheet, row); Row r = null;// 假设数据行已经存在,则获取后重写。否则自己主动创建新行。 if (pos >= 0) {
sheet.removeRow(sheet.getRow(pos));
r = sheet.createRow(pos);
} else {
r = sheet.createRow(lastRowNum + t++);
} //用于设定单元格样式
CellStyle newstyle = wb.createCellStyle(); //循环为新行创建单元格
for (int i = row.getFirstCellNum(); i < row.getLastCellNum(); i++) {
Cell cell = r.createCell(i);// 获取数据类型
cell.setCellValue(getCellValue(row.getCell(i)));// 复制单元格的值到新的单元格
// cell.setCellStyle(row.getCell(i).getCellStyle());//出错
if (row.getCell(i) == null) continue;
copyCellStyle(row.getCell(i).getCellStyle(), newstyle); // 获取原来的单元格样式
cell.setCellStyle(newstyle);// 设置样式
// sheet.autoSizeColumn(i);//自己主动跳转列宽度
}
}
out("当中检測到反复条数为:" + (rowList.size() - t) + " 。追加条数为:"+t); // 统一设定合并单元格
setMergedRegion(sheet); try {
// 又一次将数据写入Excel中
FileOutputStream outputStream = new FileOutputStream(xlsPath);
wb.write(outputStream);
outputStream.flush();
outputStream.close();
} catch (Exception e) {
out("写入Excel时错误发生。 ");
e.printStackTrace();
}
} /**
* 查找某行数据是否在Excel表中存在,返回行数。 *
* @Title: findInExcel
* @Date : 2014-9-11 下午02:23:12
* @param sheet
* @param row
* @return
*/
private int findInExcel(Sheet sheet, Row row) {
int pos = -1; try {
// 假设覆写目标文件,或者不须要比較,则直接返回
if (isOverWrite || !isNeedCompare) {
return pos;
}
for (int i = startReadPos; i <= sheet.getLastRowNum() + endReadPos; i++) {
Row r = sheet.getRow(i);
if (r != null && row != null) {
String v1 = getCellValue(r.getCell(comparePos));
String v2 = getCellValue(row.getCell(comparePos));
if (v1.equals(v2)) {
pos = i;
break;
}
}
}
} catch (Exception e) {
e.printStackTrace();
}
return pos;
} /**
* 复制一个单元格样式到目的单元格样式
*
* @param fromStyle
* @param toStyle
*/
public static void copyCellStyle(CellStyle fromStyle, CellStyle toStyle) {
toStyle.setAlignment(fromStyle.getAlignment());
// 边框和边框颜色
toStyle.setBorderBottom(fromStyle.getBorderBottom());
toStyle.setBorderLeft(fromStyle.getBorderLeft());
toStyle.setBorderRight(fromStyle.getBorderRight());
toStyle.setBorderTop(fromStyle.getBorderTop());
toStyle.setTopBorderColor(fromStyle.getTopBorderColor());
toStyle.setBottomBorderColor(fromStyle.getBottomBorderColor());
toStyle.setRightBorderColor(fromStyle.getRightBorderColor());
toStyle.setLeftBorderColor(fromStyle.getLeftBorderColor()); // 背景和前景
toStyle.setFillBackgroundColor(fromStyle.getFillBackgroundColor());
toStyle.setFillForegroundColor(fromStyle.getFillForegroundColor()); // 数据格式
toStyle.setDataFormat(fromStyle.getDataFormat());
toStyle.setFillPattern(fromStyle.getFillPattern());
// toStyle.setFont(fromStyle.getFont(null));
toStyle.setHidden(fromStyle.getHidden());
toStyle.setIndention(fromStyle.getIndention());// 首行缩进
toStyle.setLocked(fromStyle.getLocked());
toStyle.setRotation(fromStyle.getRotation());// 旋转
toStyle.setVerticalAlignment(fromStyle.getVerticalAlignment());
toStyle.setWrapText(fromStyle.getWrapText()); } /**
* 获取合并单元格的值
*
* @param sheet
* @param row
* @param column
* @return
*/
public void setMergedRegion(Sheet sheet) {
int sheetMergeCount = sheet.getNumMergedRegions(); for (int i = 0; i < sheetMergeCount; i++) {
// 获取合并单元格位置
CellRangeAddress ca = sheet.getMergedRegion(i);
int firstRow = ca.getFirstRow();
if (startReadPos - 1 > firstRow) {// 假设第一个合并单元格格式在正式数据的上面,则跳过。 continue;
}
int lastRow = ca.getLastRow();
int mergeRows = lastRow - firstRow;// 合并的行数
int firstColumn = ca.getFirstColumn();
int lastColumn = ca.getLastColumn();
// 依据合并的单元格位置和大小,调整全部的数据行格式。
for (int j = lastRow + 1; j <= sheet.getLastRowNum(); j++) {
// 设定合并单元格
sheet.addMergedRegion(new CellRangeAddress(j, j + mergeRows, firstColumn, lastColumn));
j = j + mergeRows;// 跳过已合并的行
} }
} /**
* 打印消息,
* @param msg 消息内容
* @param tr 换行
*/
private void out(String msg){
if(printMsg){
out(msg,true);
}
}
/**
* 打印消息,
* @param msg 消息内容
* @param tr 换行
*/
private void out(String msg,boolean tr){
if(printMsg){
System.out.print(msg+(tr?"\n":""));
}
} public String getExcelPath() {
return this.excelPath;
} public void setExcelPath(String excelPath) {
this.excelPath = excelPath;
} public boolean isNeedCompare() {
return isNeedCompare;
} public void setNeedCompare(boolean isNeedCompare) {
this.isNeedCompare = isNeedCompare;
} public int getComparePos() {
return comparePos;
} public void setComparePos(int comparePos) {
this.comparePos = comparePos;
} public int getStartReadPos() {
return startReadPos;
} public void setStartReadPos(int startReadPos) {
this.startReadPos = startReadPos;
} public int getEndReadPos() {
return endReadPos;
} public void setEndReadPos(int endReadPos) {
this.endReadPos = endReadPos;
} public boolean isOverWrite() {
return isOverWrite;
} public void setOverWrite(boolean isOverWrite) {
this.isOverWrite = isOverWrite;
} public boolean isOnlyReadOneSheet() {
return onlyReadOneSheet;
} public void setOnlyReadOneSheet(boolean onlyReadOneSheet) {
this.onlyReadOneSheet = onlyReadOneSheet;
} public int getSelectedSheetIdx() {
return selectedSheetIdx;
} public void setSelectedSheetIdx(int selectedSheetIdx) {
this.selectedSheetIdx = selectedSheetIdx;
} public String getSelectedSheetName() {
return selectedSheetName;
} public void setSelectedSheetName(String selectedSheetName) {
this.selectedSheetName = selectedSheetName;
} public int getStartSheetIdx() {
return startSheetIdx;
} public void setStartSheetIdx(int startSheetIdx) {
this.startSheetIdx = startSheetIdx;
} public int getEndSheetIdx() {
return endSheetIdx;
} public void setEndSheetIdx(int endSheetIdx) {
this.endSheetIdx = endSheetIdx;
} public boolean isPrintMsg() {
return printMsg;
} public void setPrintMsg(boolean printMsg) {
this.printMsg = printMsg;
}
}
以上就是工具类的所有代码。如今演示一下读取的功能:
public void testRead() {
try { ExcelUtil eu = new ExcelUtil();
eu.setExcelPath("d:\\2.xls"); System.out.println("=======測试Excel 默认 读取========");
eu.readExcel(); System.out.println("\n=======測试Excel 从第四行读取,倒数第二行结束========");
eu = eu.RestoreSettings();//还原设定
eu.setStartReadPos(3);
eu.setEndReadPos(-1);
eu.readExcel(); System.out.println("\n=======測试Excel 读取第二个sheet========");
eu = eu.RestoreSettings();//还原设定
eu.setSelectedSheetIdx(1);
eu.readExcel(); System.out.println("\n=======測试Excel 读取全部的sheet========");
eu = eu.RestoreSettings();//还原设定
eu.setOnlyReadOneSheet(false);
eu.readExcel(); } catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
操作的Excel文件内容例如以下:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQveGlhb3hpYW44MDIz/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" style="font-size:18px">
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQveGlhb3hpYW44MDIz/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" style="font-size:18px">
运行结果例如以下:
上面代码的提示和结果已经解释的非常清楚了,我就不在这里过多介绍。
如今演示多个Excel的汇总合并功能,把上面的Excel内容合并到还有一个Excel表中。这个Excel内容例如以下:
測试代码例如以下:
public void testMerge(){
try {
ExcelUtil eu1 = new ExcelUtil();//用来读取源xls
ExcelUtil eu2 = new ExcelUtil();//用来读取目标xls。用于演示合并结果
eu1.setExcelPath("d:\\2.xls");
eu2.setExcelPath("d:\\1.xls"); System.out.println("\n=======改动前,1.xls中的内容========");
eu2.readExcel(); System.out.println("\n=======读取源文件2.xls中的内容========");
eu1.setStartReadPos(3);
//eu1.setOverWrite(false);//是否覆写目标文件(默认覆写)
//eu1.setComparePos(1);//设定比較哪一列内容(默觉得0,比較第一列内容)
//eu1.setNeedCompare(false);//设定是否比較(默认值是true)。 仅仅有当不覆盖目标文件时。设置检查反复才有效。 eu1.writeExcel(eu1.readExcel(), "d:\\1.xls");//将读取到的2.xls中的数据合并到1.xls中
System.out.println("\n=======改动后,1.xls中的内容========");
eu2.readExcel();//读取合并后的1.xls的数据 } catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
运行结果例如以下:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQveGlhb3hpYW44MDIz/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQveGlhb3hpYW44MDIz/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
明明有反复的,为什么提示反复为0呢?这是由于默认对目标文件进行了覆写。直接把源文件的数据覆盖到目标文件里。
所以仅仅会显示源文件的内容。
假设把上段測试代码的13、14、15行换成以下的内容。手动还原1.xls,再測试一下:
eu1.setOverWrite(false);//是否覆写目标文件(默认覆写)
//eu1.setComparePos(1);//设定比較哪一列内容(默觉得0,比較第一列内容)
//eu1.setNeedCompare(false);//设定是否比較(默认值是true)。仅仅有当不覆盖目标文件时,设置检查反复才有效。
运行结果例如以下:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQveGlhb3hpYW44MDIz/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
这次把覆写给取消了,在合并的时候。默认会比較第一列的数据,存在的则不再追加。所以1.xls中的张三保留了。李四追加到了后面。对照上面的覆盖,能够看到,覆写时跟2.xls的顺序一致(李四在张三前面)。而不覆写,则在文档的最后运行追加操作。
我们再次改动測试代码:
eu1.setOverWrite(false);//是否覆写目标文件(默认覆写)
eu1.setComparePos(1);//设定比較哪一列内容(默觉得0,比較第一列内容)
//eu1.setNeedCompare(false);//设定是否比較(默认值是true)。 仅仅有当不覆盖目标文件时,设置检查反复才有效。
同一时候手动把1.xls中的内容改动例如以下:
运行结果例如以下:
大家能够看到,比較的对象变到的第二列,因为张三所在行的第二列与加入的内容不同样,所以张三被追加到了文档的和面。
最后再次改动測试代码。而且手动还原1.xls为原始状态。
eu1.setOverWrite(false);//是否覆写目标文件(默认覆写)
//eu1.setComparePos(1);//设定比較哪一列内容(默觉得0,比較第一列内容)
eu1.setNeedCompare(false);//设定是否比較(默认值是true)。仅仅有当不覆盖目标文件时。设置检查反复才有效。
运行结果例如以下:
这次把覆写和自己主动比較都取消了,结果就是直接在目标文件的后面进行追加操作。
代码有点多,大家可能看的有点累了,只是写这个工具类消耗了我n多脑细胞,还是希望对大家能够有所帮助。假设有什么问题,欢迎大家批评指正。
版权声明:本文博客原创文章,博客,未经同意,不得转载。
自己的包poi操作Excel工具的更多相关文章
- 自己封装的poi操作Excel工具类
自己封装的poi操作Excel工具类 在上一篇文章<使用poi读写Excel>中分享了一下poi操作Excel的简单示例,这次要分享一下我封装的一个Excel操作的工具类. 该工具类主要完 ...
- java里poi操作Excel工具类【我改】
参考原文: https://www.cnblogs.com/yizhang/p/7244917.html 我改: package test; import java.io.File; import j ...
- java里poi操作excel的工具类(兼容各版本)
转: java里poi操作excel的工具类(兼容各版本) 下面是文件内具体内容,文件下载: import java.io.FileNotFoundException; import java.io. ...
- java使用Apache POI操作excel文件
官方介绍 HSSF is the POI Project's pure Java implementation of the Excel '97(-2007) file format. XSSF is ...
- POI操作Excel(xls、xlsx)
阿帕奇官网:http://poi.apache.org/ POI3.17下载:http://poi.apache.org/download.html#POI-3.17 POI操作Excel教程(易百教 ...
- java使用POI操作excel文件,实现批量导出,和导入
一.POI的定义 JAVA中操作Excel的有两种比较主流的工具包: JXL 和 POI .jxl 只能操作Excel 95, 97, 2000也即以.xls为后缀的excel.而poi可以操作Exc ...
- POI操作Excel
POI和Excel简介 JAVA中操作Excel的有两种比较主流的工具包: JXL 和 POI .jxl 只能操作Excel 95, 97, 2000也即以.xls为后缀的excel.而poi可以操作 ...
- 利用Apache POI操作Excel
最近在做接口,有个功能是利用Excel导入汽车发动机所需零件信息到线上系统中.简单回顾一下之前学过的用java操作Excel. 1.maven配置Apache POI pom.xml中配置POIjar ...
- Java POI操作Excel注意点
excel的行索引和列索引都是从0开始,而行号和列号都是从1开始 POI·操作excel基本上都是使用索引 XSSFRow对象的 row.getLastCellNum() 方法返回的是当前行最后有效列 ...
随机推荐
- Coreseek:部门查询和增量索引代替实时索引
1.行业调查 索引系统需要通过主查询来获取所有的文档信息,一个简单的实现是整个表的数据到内存,但是这可能会导致整个表被锁定,并且使其它操作被阻止(例如:在MyISAM格款式上INSERT操作).同时, ...
- Cordova探险系列(三)
自从3.0之后.Cordova默认是关闭全部关于设备原生特性功能的,所以我们要通过加入插件来启动原生特性. 这里以Accelerometer(加速度感应器)为例,来学习怎样使用设备原生特性. 1.加入 ...
- memcache 集群
memcache 是一个分布式的缓存系统,但是本身没有提供集群功能,在大型应用的情况下容易成为瓶颈.但是客户端这个时候可以自由扩展,分两阶段实现.第一阶段:key 要先根据一定的算法映射到一台memc ...
- Codeforces 9A-Die Roll(意甲冠军)
A. Die Roll time limit per test 1 second memory limit per test 64 megabytes input standard input out ...
- 如何找到w3wp与w3svc的对应关系
在生产环境中,一般会有多个IIS进程在运行,这里面可能是有Web Garden的设置,也可能是有多个application pool在运行.而我们经常在c:\inetpub\logs目录下面,看到很多 ...
- Apple Watch 1.0 开发介绍 1.1 简介 开发苹果手表
使用Apple Watch,用户可以使用一种不显眼的方式查看信息.不用把iPhone从口袋里拿出来,就可以通过看一下手表快速获得重要信息. 作为Apple Watch的第三方app开发者,应该通过使用 ...
- Objective C Runtime 开发介绍
简介 Objective c 语言尽可能的把决定从编译推迟到链接到运行时.只要可能,它就会动态的处理事情.这就意味着它不仅仅需要一个编译器,也需要一个运行时系统来执行变异好的代码.运行时系统就好像是O ...
- 排序算法门外汉理解-Shell排序
#include <stdio.h> /* 希尔排序 基本思想:希尔排序又称为缩小增量排序,对简单插入排序的优化. (外部分组gap,组内部插入排序! ! ) 特点:一种不稳定的排序 */ ...
- Robotium调用getActivity()导致程序挂起的方法
1. 问题背景的叙述性说明 需要直接用在工作中没有项目的源代码robotium测试目标android平台launcher,该平台的基础上,当前日期的版本号android 4.4.2.之前我用来验证的可 ...
- [Apache Spark源代码阅读]天堂之门——SparkContext解析
略微了解Spark源代码的人应该都知道SparkContext,作为整个Project的程序入口,其重要性不言而喻,很多大牛也在源代码分析的文章中对其做了非常多相关的深入分析和解读.这里,结合自己前段 ...