/** * 給不一樣記錄標紅 只能是xls格式 xlsx格式不行 */ @Component public class AutomaticTestContrastExcelBL { private final Log logger = LogFactory.getLog(this.getClass()); public void dealDate(String excelFileName) { File filedir = new File(excelFileName); if (filedir.isDirectory()) { long start = System.currentTimeMillis(); String[] files = filedir.list(); BlockingQueue blockingQueue=new ArrayBlockingQueue<>(16); ThreadPoolExecutor threadPoolExecutor=new ThreadPoolExecutor((files.length + 1), (files.length + 3), 2, TimeUnit.MINUTES, blockingQueue); //ExecutorService pool = Executors.newCachedThreadPool(); //建立線程池 for (int i = 0; i < files.length; i++) { //logger.info("第: " + i); Runnable runnable= new DealExcel(files, i,excelFileName); threadPoolExecutor.execute(runnable); //DealExcel dealExcel = new DealExcel(files, i,excelFileName); //pool.submit(dealExcel); } threadPoolExecutor.shutdown();//不會觸發中斷 //threadPoolExecutor. //pool.shutdown(); //結束線程池 long end = System.currentTimeMillis(); logger.info("-----------------------------------" + (end - start) ); } } }
技術交流羣:816227112
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
package com.sinosoft.auto.thread; import com.sinosoft.utility.ExceptionUtils; import jxl.Workbook; import jxl.format.CellFormat; import jxl.format.Colour; import jxl.write.*; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import java.io.File; import java.io.FileInputStream; import java.util.HashMap; import java.util.Map; public class DealExcel implements Runnable{ private final Log logger = LogFactory.getLog(this.getClass()); private String[] files; private int index; private String fileName; public DealExcel(String[] files, int index,String fileName) { this.files = files; this.index = index; this.fileName = fileName; } @Override public void run() { logger.info(fileName +"/" + files[index]); contrastExcel(new File((fileName +"/" + files[index]))); } public void contrastExcel(File file) { try { logger.info("開始標記:" + file.getAbsoluteFile() + " ::: " + file.getName()); FileInputStream inputStream = new FileInputStream(file.getAbsoluteFile()); Workbook workbook = Workbook.getWorkbook(inputStream); WritableWorkbook wbe = Workbook.createWorkbook(file.getAbsoluteFile(), workbook); int numberOfSheets = wbe.getNumberOfSheets(); WritableCellFormat wcf = new WritableCellFormat(); wcf.setBackground(Colour.RED); for (int index = 0; index < numberOfSheets; index++) { // 每一個頁籤建立一個Sheet對象 WritableSheet sheet = wbe.getSheet(index); //獲取sheet // sheet.getColumns()返回該頁的總列數 int column_total = sheet.getColumns(); int rows = sheet.getRows(); Map<String, Integer> map = new HashMap<>(16); WritableCell cell = sheet.getWritableCell(0, 0); //獲取第一行的全部單元格 CellFormat cf = cell.getCellFormat(); //List<String> arr = new ArrayList<>(); //boolean aa = arr.contains("aa"); for (int j = 0; j < column_total; j++) { for (int i = 1; i < rows; i++) { if (i == 1) { String cellinfo1 = sheet.getCell(j, i).getContents(); map.put(cellinfo1, i); } else { String cellinfo2 = sheet.getCell(j, i).getContents(); if (!map.containsKey(cellinfo2)) { for (int k = 1; k < rows; k++) { String cellinfo3 = sheet.getCell(j, k).getContents(); Label lbl = new Label(j, k, cellinfo3, wcf);//修改後的值 sheet.addCell(lbl); } } if (i == (rows - 1)) { //循環到每列的最後一個,將清空 map.clear(); } } } } } wbe.write(); //將修改保存到workbook wbe.close(); logger.info("標記:" + file.getAbsoluteFile() + " ::: " + file.getName() + " ::: 完畢 "); } catch (Exception e) { e.printStackTrace(); logger.error("Excel文件區分標記異常" + ExceptionUtils.exceptionToString(e)); } } }