自己封裝的poi操作Excel工具類――項目經理再也不用擔心我的Excel操作了
來源:程序員人生 發布時間:2014-11-07 08:44:59 閱讀次數:4269次
在上1篇文章《使用poi讀寫Excel》中分享了1下poi操作Excel的簡單示例,這次要分享1下我封裝的1個Excel操作的工具類。
該工具類主要完成的功能是:讀取Excel、匯總Excel的功能。在讀取時,可以設定開始和結束讀取的位置、設定是不是讀取多個sheet、設定讀取那個或那些sheet等。在匯總時,如設定是不是覆蓋目標文件、設定是不是比較檢查重復內容、設定檢查重復的列索引等功能。具體來演示1下吧:
工具類源碼:
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⑴0⑵9 上午12:40:44
*/
public class ExcelUtil {
//%%%%%%%%-------常量部份 開始----------%%%%%%%%%
/**
* 默許的開始讀取的行位置為第1行(索引值為0)
*/
private final static int READ_START_POS = 0;
/**
* 默許結束讀取的行位置為最后1行(索引值=0,用負數來表示倒數第n行)
*/
private final static int READ_END_POS = 0;
/**
* 默許Excel內容的開始比較列位置為第1列(索引值為0)
*/
private final static int COMPARE_POS = 0;
/**
* 默許多文件合并的時需要做內容比較(相同的內容不重復出現)
*/
private final static boolean NEED_COMPARE = true;
/**
* 默許多文件合并的新文件遇到名稱重復時,進行覆蓋
*/
private final static boolean NEED_OVERWRITE = true;
/**
* 默許只操作1個sheet
*/
private final static boolean ONLY_ONE_SHEET = true;
/**
* 默許讀取第1個sheet中(只有當ONLY_ONE_SHEET = true時有效)
*/
private final static int SELECTED_SHEET = 0;
/**
* 默許從第1個sheet開始讀取(索引值為0)
*/
private final static int READ_START_SHEET= 0;
/**
* 默許在最后1個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;
/**
* 設定是不是只操作第1個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();
//從第1行開始讀取
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;
}
/**
* 還原設定(實際上是重新new1個新的對象并返回)
* @return
*/
public ExcelUtil RestoreSettings(){
ExcelUtil instance = new ExcelUtil(this.excelPath);
return instance;
}
/**
* 自動根據文件擴大名,調用對應的讀取方法
*
* @Title: writeExcel
* @Date : 2014⑼⑴1 下午01:50:38
* @param xlsPath
* @throws IOException
*/
public List<Row> readExcel() throws IOException{
return readExcel(this.excelPath);
}
/**
* 自動根據文件擴大名,調用對應的讀取方法
*
* @Title: writeExcel
* @Date : 2014⑼⑴1 下午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方式讀取,結果失敗!
請您確保您的文件是Excel文件,并且無損,然后再試。");
throw e2;
}
}
}
} catch (IOException e) {
throw e;
}
}
/**
* 自動根據文件擴大名,調用對應的寫入方法
*
* @Title: writeExcel
* @Date : 2014⑼⑴1 下午01:50:38
* @param rowList
* @throws IOException
*/
public void writeExcel(List<Row> rowList) throws IOException{
writeExcel(rowList,excelPath);
}
/**
* 自動根據文件擴大名,調用對應的寫入方法
*
* @Title: writeExcel
* @Date : 2014⑼⑴1 下午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方式寫入,結果失敗!
請您確保您的文件是Excel文件,并且無損,然后再試。");
throw e2;
}
}
}
} catch (IOException e) {
throw e;
}
}
/**
* 修改Excel(97-03版,xls格式)
*
* @Title: writeExcel_xls
* @Date : 2014⑼⑴1 下午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⑼⑴1 下午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();
// 如果文件不存在,則創建1個新的Excel
// wb = new HSSFWorkbook();
// wb.createSheet("Sheet1");
wb = new HSSFWorkbook(new FileInputStream(src_xlsPath));
} else {
// 如果文件存在,則讀取Excel
wb = new HSSFWorkbook(new FileInputStream(file));
}
} else {
// 如果文件不存在,則創建1個新的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⑼⑴1 下午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⑼⑴1 下午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();
// 如果文件不存在,則創建1個新的Excel
// wb = new XSSFWorkbook();
// wb.createSheet("Sheet1");
wb = new XSSFWorkbook(new FileInputStream(src_xlsPath));
} else {
// 如果文件存在,則讀取Excel
wb = new XSSFWorkbook(new FileInputStream(file));
}
} else {
// 如果文件不存在,則創建1個新的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⑼⑴1 上午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⑼⑴1 上午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⑼⑴1 上午09:53:21
*/
public List<Row> readExcel_xls() throws IOException {
return readExcel_xls(excelPath);
}
/***
* 讀取Excel(97-03版,xls格式)
*
* @throws Exception
*
* @Title: readExcel
* @Date : 2014⑼⑴1 上午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⑼⑴1 上午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⑼⑴1 上午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){ //只操作1個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("
開始讀取名為【"+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⑼⑴1 下午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);// 修改第1個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);
// 統1設定合并單元格
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⑼⑴1 下午02:23:12
* @param sheet
* @param row
* @return
*/
private int findInExcel(Sheet sheet, Row row) {
int pos = ⑴;
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;
}
/**
* 復制1個單元格樣式到目的單元格樣式
*
* @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) {// 如果第1個合并單元格格式在正式數據的上面,則跳過。
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?"
":""));
}
}
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;
}
}
以上就是工具類的全部代碼,現在演示1下讀取的功能:
public void testRead() {
try {
ExcelUtil eu = new ExcelUtil();
eu.setExcelPath("d:2.xls");
System.out.println("=======測試Excel 默許 讀取========");
eu.readExcel();
System.out.println("
=======測試Excel 從第4行讀取,倒數第2行結束========");
eu = eu.RestoreSettings();//還原設定
eu.setStartReadPos(3);
eu.setEndReadPos(⑴);
eu.readExcel();
System.out.println("
=======測試Excel 讀取第2個sheet========");
eu = eu.RestoreSettings();//還原設定
eu.setSelectedSheetIdx(1);
eu.readExcel();
System.out.println("
=======測試Excel 讀取所有的sheet========");
eu = eu.RestoreSettings();//還原設定
eu.setOnlyReadOneSheet(false);
eu.readExcel();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
操作的Excel文件內容以下:
履行結果以下:


上面代碼的提示和結果已解釋的很清楚了,我就不在這里過量介紹。
現在演示多個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("
=======修改前,1.xls中的內容========");
eu2.readExcel();
System.out.println("
=======讀取源文件2.xls中的內容========");
eu1.setStartReadPos(3);
//eu1.setOverWrite(false);//是不是覆寫目標文件(默許覆寫)
//eu1.setComparePos(1);//設定比較哪1列內容(默許為0,比較第1列內容)
//eu1.setNeedCompare(false);//設定是不是比較(默許值是true)。只有當不覆蓋目標文件時,設置檢查重復才有效。
eu1.writeExcel(eu1.readExcel(), "d:1.xls");//將讀取到的2.xls中的數據合并到1.xls中
System.out.println("
=======修改后,1.xls中的內容========");
eu2.readExcel();//讀取合并后的1.xls的數據
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
履行結果以下:
明明有重復的,為何提示重復為0呢?這是由于默許對目標文件進行了覆寫,直接把源文件的數據覆蓋到目標文件中。所以只會顯示源文件的內容。
如果把上段測試代碼的13、14、15行換成下面的內容,手動還原1.xls,再測試1下:
eu1.setOverWrite(false);//是不是覆寫目標文件(默許覆寫)
//eu1.setComparePos(1);//設定比較哪1列內容(默許為0,比較第1列內容)
//eu1.setNeedCompare(false);//設定是不是比較(默許值是true)。只有當不覆蓋目標文件時,設置檢查重復才有效。
履行結果以下:

這次把覆寫給取消了,在合并的時候,默許會比較第1列的數據,存在的則不再追加,所以1.xls中的張3保存了,李4追加到了后面。對照上面的覆蓋,可以看到,覆寫時跟2.xls的順序1致(李4在張3前面),而不覆寫,則在文檔的最后履行追加操作。
我們再次修改測試代碼:
eu1.setOverWrite(false);//是不是覆寫目標文件(默許覆寫)
eu1.setComparePos(1);//設定比較哪1列內容(默許為0,比較第1列內容)
//eu1.setNeedCompare(false);//設定是不是比較(默許值是true)。只有當不覆蓋目標文件時,設置檢查重復才有效。
同時手動把1.xls中的內容修改以下:

履行結果以下:

大家可以看到,比較的對象變到的第2列,由于張3所在行的第2列與添加的內容不相同,所以張3被追加到了文檔的和面。
最后再次修改測試代碼,并且手動還原1.xls為原始狀態。
eu1.setOverWrite(false);//是不是覆寫目標文件(默許覆寫)
//eu1.setComparePos(1);//設定比較哪1列內容(默許為0,比較第1列內容)
eu1.setNeedCompare(false);//設定是不是比較(默許值是true)。只有當不覆蓋目標文件時,設置檢查重復才有效。
履行結果以下:

這次把覆寫和自動比較都取消了,結果就是直接在目標文件的后面進行追加操作。
代碼有點多,大家可能看的有點累了,不過寫這個工具類消耗了我n多腦細胞,還是希望對大家可以有所幫助。如果有甚么問題,歡迎大家批評指正。
生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈