多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > 互聯網 > 自己封裝的poi操作Excel工具類――項目經理再也不用擔心我的Excel操作了

自己封裝的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多腦細胞,還是希望對大家可以有所幫助。如果有甚么問題,歡迎大家批評指正。


生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 免费观看福利视频 | 夜夜爽www| 午夜久久久久久 | 日韩免费福利视频 | 手机在线看片国产日韩生活片 | 欧美成人免费高清二区三区 | 密桃av| 国产成人精品一区二区不卡 | 国产97色在线 | 亚洲 | 国产全部视频 | youjizz久久 | 中文字幕一区二区在线视频 | 欧美色欧美亚洲另类二区精品 | 国产精品1区 2区 3区 | 免费国产片 | 久久国产精品视频一区 | 狠狠操视频网 | 亚洲欧美色综合一区二区在线 | 福利在线免费观看 | 欧美日韩视频在线播放 | 2020久久精品国产免费 | 日韩亚州 | 成人免费视频网 | 亚洲精品456在线观看 | 欧美午夜在线 | 黄网站大全免费 | free性欧美另类高清 | 中文字幕乱码文字醉 | 二区国产| 亚洲区小说区激情区图片区 | 中文字幕第2页 | 日韩专区欧美 | 亚洲区视频 | 黄色免费网站在线看 | 国产美女一级做受在线观看 | 免费在线观看a | 亚洲欧洲第一页 | 国产亚洲精品自在线观看 | 精品videosex性欧美 | 黄站在线观看 | 99精品久久秒播无毒不卡 |