package com.util;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
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文件操作工具类,包括读、写、合并等功能
*/
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 = "c:/测试.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 ExcelUtil(){}
public ExcelUtil(String excelPath){
this.excelPath = excelPath;
}
//%%%%%%%%-------Get/Set 开始----------%%%%%%%%%
/** Excel文件路径 */
public String getExcelPath() {return this.excelPath;}
/** Excel文件路径 */
public void setExcelPath(String excelPath) {this.excelPath = excelPath;}
/** 是否需要比较 */
public boolean isNeedCompare() {return isNeedCompare;}
/** 设定是否需要比较,默认为true(仅当不覆写目标内容是有效,即isOverWrite=false时有效) */
public void setNeedCompare(boolean isNeedCompare) {this.isNeedCompare = isNeedCompare;}
/** 开始比较的列位置 */
public int getComparePos() {return comparePos;}
/** 设定开始比较的列位置,默认为0 */
public void setComparePos(int comparePos) {this.comparePos = comparePos;}
/** 开始读取的位置 */
public int getStartReadPos() {return startReadPos;}
/** 设定开始读取的位置,默认为0 */
public void setStartReadPos(int startReadPos) {this.startReadPos = startReadPos;}
/** 结束读取的位置 */
public int getEndReadPos() {return endReadPos;}
/** 设定开始读取的位置,默认为0 */
public void setEndReadPos(int endReadPos) {this.endReadPos = endReadPos;}
/** 汇总的文件是否需要替换 */
public boolean isOverWrite() {return isOverWrite;}
/** 设定汇总的文件是否需要替换,默认为true */
public void setOverWrite(boolean isOverWrite) {this.isOverWrite = isOverWrite;}
/** 是否只操作第一个sheet */
public boolean isOnlyReadOneSheet() {return onlyReadOneSheet;}
/** 设定是否只操作第一个sheet */
public void setOnlyReadOneSheet(boolean onlyReadOneSheet) {this.onlyReadOneSheet = onlyReadOneSheet;}
/** 操作的sheet在索引值 */
public int getSelectedSheetIdx() {return selectedSheetIdx;}
/** 设定操作的sheet在索引值 */
public void setSelectedSheetIdx(int selectedSheetIdx) {this.selectedSheetIdx = selectedSheetIdx;}
/** 操作的sheet的名称 */
public String getSelectedSheetName() {return selectedSheetName;}
/** 设定操作的sheet的名称 */
public void setSelectedSheetName(String selectedSheetName) {this.selectedSheetName = selectedSheetName;}
/** 开始读取的sheet */
public int getStartSheetIdx() {return startSheetIdx;}
/** 设定开始读取的sheet,默认为0 */
public void setStartSheetIdx(int startSheetIdx) {this.startSheetIdx = startSheetIdx;}
/** 结束读取的sheet */
public int getEndSheetIdx() {return endSheetIdx;}
/** 设定结束读取的sheet,默认为0,用负数来表示倒数第n行 */
public void setEndSheetIdx(int endSheetIdx) {this.endSheetIdx = endSheetIdx;}
/** 是否打印消息 */
public boolean isPrintMsg() {return printMsg;}
/** 设定是否打印消息 */
public void setPrintMsg(boolean printMsg) {this.printMsg = printMsg;}
//%%%%%%%%-------Get/Set 结束----------%%%%%%%%%
/**
* 还原设定(其实是重新new一个新的对象并返回)
* @return
*/
public ExcelUtil RestoreSettings(){
ExcelUtil instance = new ExcelUtil(this.excelPath);
return instance;
}
/**
* 读取Excel(自动根据文件扩展名,调用对应的读取方法)
* @return
* @throws IOException
*/
public List<Row> readExcel() throws IOException{
return readExcel(this.excelPath);
}
/**
* 读取Excel(自动根据文件扩展名,调用对应的读取方法)
* @param xlsPath
* @return
* @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("xlsx".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;
}
}
/**
* 写入Excel(自动根据文件扩展名,调用对应的写入方法)
* @param rowList
* @throws IOException
*/
public void writeExcel(List<Row> rowList) throws IOException{
writeExcel(rowList,excelPath);
}
/**
* 写入Excel(自动根据文件扩展名,调用对应的写入方法)
* @param rowList
* @param xlsPath
* @throws IOException
*/
public void writeExcel(List<Row> rowList, String xlsPath) throws IOException {
//扩展名为空时,
if (xlsPath.equals("")){
throw new IOException("文件路