多線程讀寫多個文件01

/**
 * 給不一樣記錄標紅 只能是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));
        }
    }



}
相關文章
相關標籤/搜索