zoukankan      html  css  js  c++  java
  • XSSFWorkbook转为HSSFWorkbook并显示到页面

    package ibp.common.report;
    import java.io.File;
    import java.io.FileInputStream;
    import java.io.IOException;
    import java.io.InputStream;
    import java.io.StringWriter;
    
    import javax.xml.parsers.DocumentBuilderFactory;
    import javax.xml.parsers.ParserConfigurationException;
    import javax.xml.transform.OutputKeys;
    import javax.xml.transform.Transformer;
    import javax.xml.transform.TransformerException;
    import javax.xml.transform.TransformerFactory;
    import javax.xml.transform.dom.DOMSource;
    import javax.xml.transform.stream.StreamResult;
    
    import org.apache.poi.hssf.converter.ExcelToHtmlConverter;
    import org.apache.poi.hssf.usermodel.HSSFWorkbook;
    import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
    import org.apache.poi.xssf.usermodel.XSSFWorkbook;
    public class TransToImgUtil {
         public static String convertExceltoHtml(String path) throws IOException,ParserConfigurationException, TransformerException,InvalidFormatException {
             HSSFWorkbook workBook = null;
             String content = null;
             StringWriter writer = null;
             File excelFile = new File(path);
             InputStream is = new FileInputStream(excelFile);
             String suffix = path.substring(path.lastIndexOf("."));
             if(suffix.equals(".xlsx")){
                 //将07版转化为03版
                 Xssf2Hssf xlsx2xls = new Xssf2Hssf();
                 XSSFWorkbook xSSFWorkbook = new XSSFWorkbook(is);
                 workBook = new HSSFWorkbook();
                 xlsx2xls.transformXSSF(xSSFWorkbook, workBook);
             }else{
                 workBook = new HSSFWorkbook(is);
             }
             try {
                 ExcelToHtmlConverter converter = new ExcelToHtmlConverter(DocumentBuilderFactory.newInstance().newDocumentBuilder().newDocument());
                 converter.setOutputColumnHeaders(false);// 不显示列的表头
                 converter.setOutputRowNumbers(false);// 不显示行的表头
                 converter.processWorkbook(workBook);
     
                 writer = new StringWriter();
                 Transformer serializer = TransformerFactory.newInstance().newTransformer();
                 serializer.setOutputProperty(OutputKeys.ENCODING, "UTF-8");
                 serializer.setOutputProperty(OutputKeys.INDENT, "yes");
                 serializer.setOutputProperty(OutputKeys.METHOD, "html");
                 serializer.transform(new DOMSource(converter.getDocument()),
                         new StreamResult(writer));
                 content = writer.toString();
                 writer.close();
             } finally {
                 try {
                     if (is != null) {
                         is.close();
                     }
                     if (writer != null) {
                         writer.close();
                     }
                 } catch (IOException e) {
                     e.printStackTrace();
                 }
             }
             return content;
         }
    }
    package ibp.common.report;
    
    import java.util.HashMap;
    
    import org.apache.poi.hssf.usermodel.HSSFCell;
    import org.apache.poi.hssf.usermodel.HSSFCellStyle;
    import org.apache.poi.hssf.usermodel.HSSFFont;
    import org.apache.poi.hssf.usermodel.HSSFRow;
    import org.apache.poi.hssf.usermodel.HSSFSheet;
    import org.apache.poi.hssf.usermodel.HSSFWorkbook;
    import org.apache.poi.ss.usermodel.Cell;
    import org.apache.poi.ss.usermodel.DataFormat;
    import org.apache.poi.ss.usermodel.Row;
    import org.apache.poi.ss.usermodel.Sheet;
    import org.apache.poi.ss.util.CellRangeAddress;
    import org.apache.poi.xssf.usermodel.XSSFCell;
    import org.apache.poi.xssf.usermodel.XSSFCellStyle;
    import org.apache.poi.xssf.usermodel.XSSFFont;
    import org.apache.poi.xssf.usermodel.XSSFRow;
    import org.apache.poi.xssf.usermodel.XSSFSheet;
    import org.apache.poi.xssf.usermodel.XSSFWorkbook;
      
    public class Xssf2Hssf {  
      
        private int lastColumn = 0;  
        private HashMap<Integer, HSSFCellStyle> styleMap = new HashMap();  
      
        public void transformXSSF(XSSFWorkbook workbookOld,  
                HSSFWorkbook workbookNew) {
            String call = "transform ";  
            System.out.println(call + "Workbook");  
            HSSFSheet sheetNew;  
            XSSFSheet sheetOld;  
            // TODO::workbookNew.setForceFormulaRecalculation(workbookOld.getForceFormulaRecalculation());  
            // workbookNew.setHidden(workbookOld.isHidden()); //ST@03.05.2012 -  
            // von Apache noch nicht implementiert  
            workbookNew.setMissingCellPolicy(workbookOld.getMissingCellPolicy());  
      
            for (int i = 0; i < workbookOld.getNumberOfSheets(); i++) {  
                sheetOld = workbookOld.getSheetAt(i);  
                sheetNew = workbookNew.getSheet(sheetOld.getSheetName());  
                System.out.println(call + "Sheet Name: " + sheetOld.getSheetName());  
                sheetNew = workbookNew.createSheet(sheetOld.getSheetName());  
                this.transform(workbookOld, workbookNew, sheetOld, sheetNew);  
            }  
            System.out.println(call + "Styles size: " + this.styleMap.size());  
            System.out.println(call + "abgeschlossen");  
        }  
      
        private void transform(XSSFWorkbook workbookOld, HSSFWorkbook workbookNew,  
                XSSFSheet sheetOld, HSSFSheet sheetNew) {  
            System.out.println("transform Sheet");  
      
            sheetNew.setDisplayFormulas(sheetOld.isDisplayFormulas());  
            sheetNew.setDisplayGridlines(sheetOld.isDisplayGridlines());  
            sheetNew.setDisplayGuts(sheetOld.getDisplayGuts());  
            sheetNew.setDisplayRowColHeadings(sheetOld.isDisplayRowColHeadings());  
            sheetNew.setDisplayZeros(sheetOld.isDisplayZeros());  
            sheetNew.setFitToPage(sheetOld.getFitToPage());  
            //  
            // TODO::sheetNew.setForceFormulaRecalculation(sheetOld.getForceFormulaRecalculation());  
            sheetNew.setHorizontallyCenter(sheetOld.getHorizontallyCenter());  
            sheetNew.setMargin(Sheet.BottomMargin,  
                    sheetOld.getMargin(Sheet.BottomMargin));  
            sheetNew.setMargin(Sheet.FooterMargin,  
                    sheetOld.getMargin(Sheet.FooterMargin));  
            sheetNew.setMargin(Sheet.HeaderMargin,  
                    sheetOld.getMargin(Sheet.HeaderMargin));  
            sheetNew.setMargin(Sheet.LeftMargin,  
                    sheetOld.getMargin(Sheet.LeftMargin));  
            sheetNew.setMargin(Sheet.RightMargin,  
                    sheetOld.getMargin(Sheet.RightMargin));  
            sheetNew.setMargin(Sheet.TopMargin, sheetOld.getMargin(Sheet.TopMargin));  
            sheetNew.setPrintGridlines(sheetNew.isPrintGridlines());  
            sheetNew.setRightToLeft(sheetNew.isRightToLeft());  
            sheetNew.setRowSumsBelow(sheetNew.getRowSumsBelow());  
            sheetNew.setRowSumsRight(sheetNew.getRowSumsRight());  
            sheetNew.setVerticallyCenter(sheetOld.getVerticallyCenter());  
      
            HSSFRow rowNew;  
            for (Row row : sheetOld) {  
                rowNew = sheetNew.createRow(row.getRowNum());  
                if (rowNew != null)  
                    this.transform(workbookOld, workbookNew, (XSSFRow) row, rowNew);  
            }  
      
            for (int i = 0; i < this.lastColumn; i++) {  
                sheetNew.setColumnWidth(i, sheetOld.getColumnWidth(i));  
                sheetNew.setColumnHidden(i, sheetOld.isColumnHidden(i));  
            }  
      
            for (int i = 0; i < sheetOld.getNumMergedRegions(); i++) {  
                CellRangeAddress merged = sheetOld.getMergedRegion(i);  
                sheetNew.addMergedRegion(merged);  
            }  
        }  
      
        private void transform(XSSFWorkbook workbookOld, HSSFWorkbook workbookNew,  
                XSSFRow rowOld, HSSFRow rowNew) {  
            HSSFCell cellNew;  
            rowNew.setHeight(rowOld.getHeight());  
            // TODO::if (rowOld.getRowStyle() != null) {  
            /* 
             * Integer hash = rowOld.getRowStyle().hashCode(); if 
             * (!this.styleMap.containsKey(hash)) 
             * this.transform(workbookOld,workbookNew,hash, 
             * (XSSFCellStyle)rowOld.getRowStyle 
             * (),(HSSFCellStyle)workbookNew.createCellStyle()); 
             * rowNew.setRowStyle(this.styleMap.get(hash)); } 
             */  
            for (Cell cell : rowOld) {  
                cellNew = rowNew.createCell(cell.getColumnIndex(),  
                        cell.getCellType());  
                if (cellNew != null)  
                    this.transform(workbookOld, workbookNew, (XSSFCell) cell,  
                            cellNew);  
            }  
            this.lastColumn = Math.max(this.lastColumn, rowOld.getLastCellNum());  
        }  
      
        private void transform(XSSFWorkbook workbookOld, HSSFWorkbook workbookNew,  
                XSSFCell cellOld, HSSFCell cellNew) {  
            cellNew.setCellComment(cellOld.getCellComment());  
      
            Integer hash = cellOld.getCellStyle().hashCode();  
            if (this.styleMap != null && !this.styleMap.containsKey(hash)) {  
                this.transform(workbookOld, workbookNew, hash,  
                        cellOld.getCellStyle(),  
                        (HSSFCellStyle) workbookNew.createCellStyle());  
            }  
            cellNew.setCellStyle(this.styleMap.get(hash));  
      
            switch (cellOld.getCellType()) {  
            case Cell.CELL_TYPE_BLANK:  
                break;  
            case Cell.CELL_TYPE_BOOLEAN:  
                cellNew.setCellValue(cellOld.getBooleanCellValue());  
                break;  
            case Cell.CELL_TYPE_ERROR:  
                cellNew.setCellValue(cellOld.getErrorCellValue());  
                break;  
            case Cell.CELL_TYPE_FORMULA:  
                cellNew.setCellValue(cellOld.getCellFormula());  
                break;  
            case Cell.CELL_TYPE_NUMERIC:  
                cellNew.setCellValue(cellOld.getNumericCellValue());  
                break;  
            case Cell.CELL_TYPE_STRING:  
                cellNew.setCellValue(cellOld.getStringCellValue());  
                break;  
            default:  
                System.out.println("transform: Unbekannter Zellentyp "  
                        + cellOld.getCellType());  
            }  
        }  
      
        private void transform(XSSFWorkbook workbookOld, HSSFWorkbook workbookNew,  
                Integer hash, XSSFCellStyle styleOld, HSSFCellStyle styleNew) {  
            styleNew.setAlignment(styleOld.getAlignment());  
            styleNew.setBorderBottom(styleOld.getBorderBottom());  
            styleNew.setBorderLeft(styleOld.getBorderLeft());  
            styleNew.setBorderRight(styleOld.getBorderRight());  
            styleNew.setBorderTop(styleOld.getBorderTop());  
            styleNew.setDataFormat(this.transform(workbookOld, workbookNew,  
                    styleOld.getDataFormat()));  
            styleNew.setFillBackgroundColor(styleOld.getFillBackgroundColor());  
            styleNew.setFillForegroundColor(styleOld.getFillForegroundColor());  
            styleNew.setFillPattern(styleOld.getFillPattern());  
            styleNew.setFont(this.transform(workbookNew,  
                    (XSSFFont) styleOld.getFont()));
            styleNew.setHidden(styleOld.getHidden());  
            styleNew.setIndention(styleOld.getIndention());  
            styleNew.setLocked(styleOld.getLocked());  
            styleNew.setVerticalAlignment(styleOld.getVerticalAlignment());  
            styleNew.setWrapText(styleOld.getWrapText());  
            this.styleMap.put(hash, styleNew);  
        }  
      
        private short transform(XSSFWorkbook workbookOld, HSSFWorkbook workbookNew,  
                short index) {  
            DataFormat formatOld = workbookOld.createDataFormat();  
            DataFormat formatNew = workbookNew.createDataFormat();  
            return formatNew.getFormat(formatOld.getFormat(index));  
        }  
      
        private HSSFFont transform(HSSFWorkbook workbookNew, XSSFFont fontOld) {  
            HSSFFont fontNew = workbookNew.createFont();  
            fontNew.setBoldweight(fontOld.getBoldweight());  
            fontNew.setCharSet(fontOld.getCharSet());  
            fontNew.setColor(fontOld.getColor());  
            fontNew.setFontName(fontOld.getFontName());  
            fontNew.setFontHeight(fontOld.getFontHeight());  
            fontNew.setItalic(fontOld.getItalic());  
            fontNew.setStrikeout(fontOld.getStrikeout());  
            fontNew.setTypeOffset(fontOld.getTypeOffset());  
            fontNew.setUnderline(fontOld.getUnderline());  
            return fontNew;  
        }  
    }

    参考来源:https://www.cnblogs.com/zhouxuan323/p/6044850.html

    http://blog.csdn.net/leozhou13/article/details/50371218

  • 相关阅读:
    react 滑动删除组件
    004-Java进制转换
    003-JavaString数据类型
    002-Java数据类型
    001-Java命名规范
    【leetcode】804
    【MySQL】基本语句
    【python】
    hiveSql常见错误记录
    【数据库】-基本特性
  • 原文地址:https://www.cnblogs.com/seeusmile-cnblog/p/8027911.html
Copyright © 2011-2022 走看看