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