热搜:NVER node 开发 php

Excel 转成 Html Excel 预览_html/css_WEB-ITnose

2024-11-07 21:30:01
Excel 转成 Html Excel 预览_html/css_WEB-ITnose

基于Poi demo做的,效果还不错,这里给大家分享下,先看看效果




效果基本上一致,这里说下如何做的

1.合并单元格的处理

    

/**

      * 根据合并输出内容,处理合并单元格事情

      * @param formatAsString

      */

     private void handerMergedString(String formatAsString) {

         String[] strArr = formatAsString.split( ":" );

         int startCol = strArr[0].charAt(0) - 65;

         int startRol = Integer.valueOf(strArr[0].substring(1));

         int endCol = strArr[1].charAt(0) - 65;

         int endRol = Integer.valueOf(strArr[1].substring(1));

         mergedCache.put(startRol +  "_"  + startCol,  new  Integer[] { endRol - startRol + 1,

                 endCol - startCol + 1 });

         for  (int i = startRol; i 

             for  (int j = startCol; j 

                 notNeedCread.add(i +  "_"  + j);

             }

         }

         notNeedCread.remove(startRol +  "_"  + startCol);

     }

把整个sheet的合并单元格,存放起来,然后便利的时候判断下,给td写写 rowspan和colsopan 就可以了,相对比较简单


2.css的设置

private void styleContents(CellStyle style) {

         if  (style.getAlignment() != 2) {

             styleOut( "text-align" , style.getAlignment(), ALIGN);

             styleOut( "vertical-align" , style.getAlignment(), VERTICAL_ALIGN);

         }

         helper.colorStyles(style, out);

     }

 

     private void fontStyle(Font font) {

         if  (font.getBoldweight() >= Font.BOLDWEIGHT_BOLD)

             out.format( "  font-weight: bold;%n" );

         if  (font.getItalic())

             out.format( "  font-style: italic;%n" );

         out.format( "  font-family: %s;%n" , font.getFontName());

 

         int fontheight = font.getFontHeightInPoints();

         if  (fontheight == 9) {

             fontheight = 10;

         }

         out.format( "  font-size: %dpt;%n" , fontheight);

         helper.styleColor(out,  "color" , getColor(font));

     }


从cellStyle 里面吧值获取出来,然后填写到css当中,已经font的css,这个理font和style要区分因为后面复杂的单元格要迭代设置的font,另外

03和07版本很多不同的东西,需要分开设置


3.值的获取--比较重要和复杂的

public String getHtmlValue(Cell cell) {

         if  (Cell.CELL_TYPE_BOOLEAN == cell.getCellType()

             || Cell.CELL_TYPE_NUMERIC == cell.getCellType()) {

             cell.setCellType(Cell.CELL_TYPE_STRING);

             return  cell.getStringCellValue();

         }  else  if  (Cell.CELL_TYPE_STRING == cell.getCellType()) {

             if  (cell.getRichStringCellValue().numFormattingRuns() == 0) {

                 return  XmlEscapers.xmlContentEscaper().escape(cell.getStringCellValue());

             }  else  if  (is07) {

                 return  getXSSFRichString((XSSFRichTextString) cell.getRichStringCellValue());

             }  else  {

                 return  getHSSFRichString((HSSFRichTextString) cell.getRichStringCellValue());

             }

         }

         return  "" ;

     }


判断cell类型,然后设置值,如果是String,需要判断是不是复杂的text,如果是,需要按照03,和07分别处理,迭代列类型列表然后输出


总的来说比自己想想的容易的多


使用方法---只能一个sheet一个sheet的输出

/**

  * Excel 变成界面

  * @author JueYue

  * @date 2015年5月10日 上午11:51:48

  */

public final class ExcelToHtmlUtil {

 

     private ExcelToHtmlUtil() {

     }

 

     /**

      * 转换成为Table

      * @param wb Excel

      * @return

      */

     public static String toTableHtml(Workbook wb) {

         return  new  ExcelToHtmlServer(wb,  false , 0).printPage();

     }

 

     /**

      * 转换成为Table

      * @param wb Excel

      * @param sheetNum sheetNum

      * @return

      */

     public static String toTableHtml(Workbook wb, int sheetNum) {

         return  new  ExcelToHtmlServer(wb,  false , sheetNum).printPage();

     }

 

     /**

      * 转换成为完整界面

      * @param wb Excel

      * @param sheetNum sheetNum

      * @return

      */

     public static String toAllHtml(Workbook wb) {

         return  new  ExcelToHtmlServer(wb,  true , 0).printPage();

     }

 

     /**

      * 转换成为完整界面

      * @param wb Excel

      * @param sheetNum sheetNum

      * @return

      */

     public static String toAllHtml(Workbook wb, int sheetNum) {

         return  new  ExcelToHtmlServer(wb,  true , sheetNum).printPage();

     }

 

}



源码地址EasyPoi