All Downloads are FREE. Search and download functionalities are using the official Maven repository.

cn.afterturn.easypoi.excel.html.ExcelToHtmlService Maven / Gradle / Ivy

package cn.afterturn.easypoi.excel.html;

import cn.afterturn.easypoi.excel.entity.ExcelToHtmlParams;
import cn.afterturn.easypoi.excel.html.helper.CellValueHelper;
import cn.afterturn.easypoi.excel.html.helper.MergedRegionHelper;
import cn.afterturn.easypoi.excel.html.helper.StyleHelper;
import cn.afterturn.easypoi.util.PoiPublicUtil;
import org.apache.commons.lang3.StringUtils;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.text.SimpleDateFormat;
import java.util.*;

/**
 * Excel转换成Html 服务
 *
 * @author JueYue
 * 2015年5月10日 上午11:41:15
 */
public class ExcelToHtmlService {

    private static final Logger LOGGER = LoggerFactory
            .getLogger(ExcelToHtmlService.class);

    private static final SimpleDateFormat DATE_FORMAT = new SimpleDateFormat("yyyy_MM_dd");

    private String today;

    private Workbook wb;
    private int      sheetNum;
    private int      cssRandom;

    /*是不是完成界面*/
    private              boolean   completeHTML;
    private              Formatter out;
    /*已经完成范围处理*/
    private              boolean   gotBounds;
    private              int       firstColumn;
    private              int       endColumn;
    private              String    imageCachePath;
    private              boolean   showRowNum;
    private              boolean   showColumnHead;
    private static final String    COL_HEAD_CLASS = "colHeader";
    private static final String    ROW_HEAD_CLASS = "rowHeader";

    private static final String DEFAULTS_CLASS = "excelDefaults";

    //图片缓存
    private Map pictures = new HashMap();

    public ExcelToHtmlService(ExcelToHtmlParams params) {
        this.wb = params.getWb();
        this.completeHTML = params.isCompleteHTML();
        this.sheetNum = params.getSheetNum();
        this.cssRandom = (int) Math.ceil(Math.random() * 1000);
        this.imageCachePath = params.getPath();
        this.showRowNum = params.isShowRowNum();
        this.showColumnHead = params.isShowColumnHead();
        this.today = new SimpleDateFormat("yyyy_MM_dd").format(new Date());
    }

    public String printPage() {
        try {
            ensureOut();
            if (completeHTML) {
                out.format("%n");
                out.format("%n");
                out.format(
                        "%n");
                out.format("%n");
            }
            if (StringUtils.isNotEmpty(imageCachePath)) {
                getPictures();
            }
            new StyleHelper(wb, out, sheetNum, cssRandom);
            if (completeHTML) {
                out.format("%n");
                out.format("%n");
            }
            print();
            if (completeHTML) {
                out.format("%n");
                out.format("%n");
            }
            return out.toString();
        } catch (Exception e) {
            LOGGER.error(e.getMessage(), e);
        } finally {
            if (out != null) {
                out.close();
            }
        }
        return null;
    }

    /**
     * 获取Sheet缓存的图片
     */
    private void getPictures() {
        if (wb instanceof XSSFWorkbook) {
            pictures = PoiPublicUtil.getSheetPictrues07((XSSFSheet) wb.getSheetAt(sheetNum),
                    (XSSFWorkbook) wb);
        } else {
            pictures = PoiPublicUtil.getSheetPictrues03((HSSFSheet) wb.getSheetAt(sheetNum),
                    (HSSFWorkbook) wb);
        }
    }

    private void print() {
        printSheets();
    }

    private void ensureOut() {
        if (out == null) {
            out = new Formatter(new StringBuilder());
        }
    }

    private void printSheets() {
        Sheet sheet = wb.getSheetAt(sheetNum);
        printSheet(sheet);
    }

    private void printSheet(Sheet sheet) {
        out.format("%n", DEFAULTS_CLASS, getTableWidth(sheet));
        printCols(sheet);
        printSheetContent(sheet);
        out.format("
%n"); } private void printCols(Sheet sheet) { if (showRowNum) { out.format("%n", PoiPublicUtil.getNumDigits(sheet.getLastRowNum()) * 18); } ensureColumnBounds(sheet); for (int i = firstColumn; i < endColumn; i++) { out.format("%n", sheet.getColumnWidth(i) / 16); } } private int getTableWidth(Sheet sheet) { ensureColumnBounds(sheet); int width = 0; for (int i = firstColumn; i < endColumn; i++) { width = width + (sheet.getColumnWidth(i) / 16); } return width; } private void ensureColumnBounds(Sheet sheet) { if (gotBounds) { return; } int lastRow = sheet.getLastRowNum(); firstColumn = (lastRow > 1 ? Integer.MAX_VALUE : 0); endColumn = 0; for (int i = 0; i < lastRow; i++) { Row row = sheet.getRow(i); if(null == row){ continue; } short firstCell = row.getFirstCellNum(); if (firstCell >= 0) { firstColumn = Math.min(firstColumn, firstCell); endColumn = Math.max(endColumn, row.getLastCellNum()); } } gotBounds = true; } @SuppressWarnings("unused") /**本来是用来生成 A,B 那个列名称的**/ private void printColumnHeads(Sheet sheet) { out.format("%n"); out.format(" %n", COL_HEAD_CLASS); out.format(" ◊%n", COL_HEAD_CLASS); StringBuilder colName = new StringBuilder(); for (int i = firstColumn; i < endColumn; i++) { colName.setLength(0); int cnum = i; do { colName.insert(0, (char) ('A' + cnum % 26)); cnum /= 26; } while (cnum > 0); out.format(" %s%n", COL_HEAD_CLASS, colName); } out.format(" %n"); out.format("%n"); } private void printSheetContent(Sheet sheet) { if (showColumnHead) { printColumnHeads(sheet); } MergedRegionHelper mergedRegionHelper = new MergedRegionHelper(sheet); CellValueHelper cellValueHelper = new CellValueHelper(wb, cssRandom); out.format("%n"); Iterator rows = sheet.rowIterator(); int rowIndex = 1; while (rows.hasNext()) { Row row = rows.next(); out.format(" %n", row.getHeight() / 15); if (showRowNum) { out.format(" %d%n", row.getRowNum() + 1); } for (int i = firstColumn; i < endColumn; i++) { if (mergedRegionHelper.isNeedCreate(rowIndex, i)) { String content = " "; CellStyle style = null; if (i >= row.getFirstCellNum() && i < row.getLastCellNum()) { Cell cell = row.getCell(i); if (cell != null) { style = cell.getCellStyle(); content = cellValueHelper.getHtmlValue(cell); } } if (pictures.containsKey((rowIndex - 1) + "_" + i)) { content = ""; } if (mergedRegionHelper.isMergedRegion(rowIndex, i)) { Integer[] rowAndColSpan = mergedRegionHelper.getRowAndColSpan(rowIndex, i); out.format(" %s%n", rowAndColSpan[0], rowAndColSpan[1], styleName(style), content); } else { out.format(" %s%n", styleName(style), content); } } } out.format(" %n"); rowIndex++; } out.format("%n"); } /** * 获取图片最大宽度 * * @param colIndex * @param sheet * @param rowAndColSpan * @return */ private int getImageMaxWidth(Integer[] rowAndColSpan, int colIndex, Sheet sheet) { if (rowAndColSpan == null) { return sheet.getColumnWidth(colIndex) / 32; } int maxWidth = 0; for (int i = 0; i < rowAndColSpan[1]; i++) { maxWidth += sheet.getColumnWidth(colIndex + i) / 32; } return maxWidth; } /** * 获取图片路径 * * @param pictureData * @return */ private String getImageSrc(PictureData pictureData) { if (pictureData == null) { return ""; } byte[] data = pictureData.getData(); //直接输出到HTML使用BASE64Encoder // 加密 Base64.Encoder encoder = Base64.getEncoder(); return encoder.encodeToString(data); /*String fileName = "pic" + Math.round(Math.random() * 100000000000L); fileName += "." + PoiPublicUtil.getFileExtendName(data); if (!imageCachePath.startsWith("/") && !imageCachePath.contains(":")) { imageCachePath = FileUtilTest.getWebRootPath(imageCachePath); } File savefile = new File(imageCachePath + "/" + today); if (!savefile.exists()) { savefile.mkdirs(); } savefile = new File(imageCachePath + "/" + today + "/" + fileName); FileOutputStream fos = null; try { fos = new FileOutputStream(savefile); fos.write(data); } catch (Exception e) { LOGGER.error(e.getMessage(), e); } finally { try { fos.close(); } catch (Exception e) { LOGGER.error(e.getMessage(), e); } } return imageCachePath + "/" + today + "/" + fileName;*/ } private String styleName(CellStyle style) { if (style == null) { return ""; } return String.format("style_%02x_%s font_%s_%s", style.getIndex(), cssRandom, style.getFontIndex(), cssRandom); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy