`
javasee
  • 浏览: 968706 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

java poi对excel处理 用jsp显示处理

阅读更多

import java.io.File;
import java.io.FileInputStream;
import java.text.DecimalFormat;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Set;

import oracle.net.aso.r;

import org.apache.openjpa.lib.conf.StringValue;
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.HSSFPalette;
import org.apache.poi.hssf.usermodel.HSSFRichTextString;
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.hssf.util.HSSFColor;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.util.CellRangeAddress;

import bsh.org.objectweb.asm.Label;

/**
 * poi-3.7
 *
 * @author Administrator
 *
 */
public class ExcelUtils {

 public ExcelUtils() {
  
 }
   
 private int sumWidth;
 
 public static void main(String args[]) {
  ExcelUtils eu = new ExcelUtils();
  // String filepath="E:\\myproject\\eipplugin\\test.xls";
  String filepath = "D:\\1.xls";
  HSSFWorkbook workbook = eu.readExcelFile(filepath);
  String exceltitle = eu.getFirstRowContent(workbook, 0);
  // System.out.println(exceltitle);
  // StringBuffer htmlsource=eu.excelToHtmlSource(workbook, 0);
  StringBuffer htmlsource = eu.excelToHtmlJs(workbook, 0);
  StringBuffer htmlbuf = new StringBuffer("");
  htmlbuf.append(eu.headerHtmlStart(exceltitle));

  htmlbuf.append(htmlsource);

  htmlbuf.append(eu.headerHtmlEnd());

  // htmlbuf.append(eu.excelToHtmlSource(workbook, 0));

  htmlbuf.append(eu.bodyHtml());
  htmlbuf.append(eu.bodyHtmlEnd());

  try {
   FileUtils.writeFile("E:\\excel\\小学\\excel3.html ", htmlbuf);
  } catch (Exception e) {
   e.printStackTrace();
  }
  // System.out.println(htmlsource);
 }

 public StringBuffer headerHtmlStart(String title) {
  StringBuffer sb = new StringBuffer("");
  sb.append("<html>\n");
  sb.append("<head>\n");
  sb
    .append("<meta http-equiv=\"Content-Type\" content=\"text/html; charset=gb2312\" />\n");
  sb.append("<META HTTP-EQUIV=\"pragma\" CONTENT=\"no-cache\">\n");
  sb
    .append("<META HTTP-EQUIV=\"Cache-Control\" CONTENT=\"no-cache, must-revalidate\">\n");
  sb.append("<META HTTP-EQUIV=\"expires\" CONTENT=\"0\">\n");

  sb.append("<title>" + title + "</title>\n");
 // sb.append("<link href=\"js/style.css\" rel=\"stylesheet\" type=\"text/css\" />\n");
  sb.append("<SCRIPT type=\"text/javascript\" src=\"js/jquery-1.3.2.min.js\"></SCRIPT>\n");
  sb.append("<script type=\"text/javascript\" src=\"js/scripts-pack.js\"></script>\n");
  sb.append("<script type=\"text/javascript\" src=\"js/jquery-ui-1.7.2.custom.min.js\"></script>\n");
  sb.append("<script type=\"text/javascript\" src=\"js/jquery.chromatable.js\"></script>\n");
  return sb;
 }

 public StringBuffer headerHtmlEnd() {
  StringBuffer sb = new StringBuffer("");
  sb.append("</head>\n");
  sb.append("<body>\n");// 进入页面就刷新下

  return sb;
 }

 public StringBuffer bodyHtml() {
  StringBuffer sb = new StringBuffer("");
  sb.append("<a id=\"deldata\" href=\"#\">查看全部结果</a>\n");
  sb.append("<br/>\n");
  sb.append("<table id='exceltitletable' width=\""+this.getSumWidth()+"\"   border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n");
  sb.append("</table>\n");
  sb.append("<table id='exceltable'  width=\""+this.getSumWidth()+"\"  border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n");

  sb.append("<thead>  \n");//width=\""+this.getSumWidth()+"\"  width=\""+this.getSumWidth()+"\"
  sb.append("</thead>\n");
  sb.append("<tbody>\n");
  sb.append("</tbody>\n");
  sb.append("</table>\n");
  return sb;
 }

 public StringBuffer bodyHtml(HSSFWorkbook workbook, int sheetindex) {
  int trwidth = this.getTrWidth(workbook, sheetindex);
  StringBuffer sb = new StringBuffer("");
  sb.append("<a id=\"deldata\" href=\"#\">查看全部结果</a>\n");
  sb.append("<br/>\n");
  sb
    .append("<table id='exceltitletable' border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n");
  sb.append("</table>\n");
  sb.append("<table id='exceltable' ");
  sb.append("border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n");

  sb.append("<thead>  \n");
  sb.append("</thead>\n");
  sb.append("<tbody>\n");
  sb.append("</tbody>\n");
  sb.append("</table>\n");
  return sb;
 }

 public StringBuffer bodyHtmlEnd() {
  StringBuffer sb = new StringBuffer("");
  sb.append("</body>\n");
  sb.append("</html>\n");
  return sb;
 }

 private int getTdWidth(Sheet sheet, int startCol, int endCol) {
  int tdwidth = 0;
  for (int i = startCol; i <= endCol; i++) {
   int tempwidth = sheet.getColumnWidth(i) / 32;
   tdwidth = tdwidth + tempwidth;

  }
  return tdwidth;
 }

 public StringBuffer excelToHtmlJs(HSSFWorkbook workbook, int sheetindex) {
  StringBuffer sb = new StringBuffer("");

  HSSFSheet sheet = workbook.getSheetAt(sheetindex);
 
  int lastRowNum = sheet.getLastRowNum();
  System.out.println("lastRowNum=" + lastRowNum);
  Map<String, String> map[] = getRowSpanColSpanMap(sheet);
  
  HSSFRow row1 = null;
  HSSFCell cell1 = null;
  int lastColNums=0;
  for (int rowNum = sheet.getFirstRowNum(),i=0; rowNum <= lastRowNum; rowNum++,i++) {
   row1 = (HSSFRow) sheet.getRow(rowNum);
   
   if ( !" ".equals(row1)) {
     lastColNums = row1.getLastCellNum();
    int sumWidth=0;// 求头部的总width
    System.out.println("lastColNums:"+lastColNums);
   }
   
           // break;
   
   
  for (int colNum = 0,j=0; colNum < lastColNums; colNum++,j++) {
    cell1 = row1.getCell(colNum);
    int tdwidth = sheet.getColumnWidth(colNum) / 32;
    //求头的总的width
    // System.out.println("tdwidth="+tdwidth);
     sumWidth+=tdwidth;  
     this.setSumWidth(sumWidth);
     System.out.println("tdwidth="+tdwidth);
     
     
    }
  break;
  }
  
  sb.append("<script type=\"text/javascript\">\n");
  int sum=this.getSumWidth();//
  System.out.println("sum="+sum);
  sb.append(" $(document).ready(function(){\n");
  sb.append(" $(\"#exceltable\").chromatable({\n");
  sb.append(" width: '"+sum+"px',\n"); // specify 100%, auto, or a fixed pixel amount
  sb.append(" height: \"400px\",\n");
  sb.append(" scrolling: \"yes\"\n"); // must have the jquery-1.3.2.min.js script installed to use
  sb.append(" });\n");
  sb.append(" });\n");
  sb.append("  $(document).ready(function() {\n");

  // sb.append("<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n");

  HSSFRow row = null;

  HSSFCell cell = null;
  // System.out.println(sheet.getPhysicalNumberOfRows());
  List rangennumList = this.getRangeRows(sheet);
  int rangenum = rangennumList.size();
  System.out.println("Srangenum=" + rangenum);
  
  if(rangenum==2){
   rangenum+=1;
  }
  if(rangenum==3){
    rangenum+=1;
  }
  
  if(rangenum==7){
     rangenum-=2;
   }
      if (rangenum==12) {
  rangenum-=6;
    }
      if (rangenum==13) {
    rangenum-=7;
      }
      if (rangenum==8) {
      rangenum-=3;
      }
      if(rangenum==11){
       rangenum-=5;
      }
      if(rangenum==10){
       rangenum-=4;
      }
      if(rangenum==9){
       rangenum-=3;
      }
      if(rangenum==14){
       rangenum-=8;
      }
      if(rangenum==18){
       rangenum/=3;
      }
      if(rangenum==15){
       rangenum-=9;
      }
      if(rangenum==16){
       rangenum-=10;
      }
      if(rangenum==17){
       rangenum-=12;
      }

  System.out.println("Trangenum=" + rangenum);

  for (int rowNum = sheet.getFirstRowNum(); rowNum <= lastRowNum; rowNum++) {
   StringBuffer strbuf = new StringBuffer("");
   int trwidth = 0;
   row = (HSSFRow) sheet.getRow(rowNum);
   if (row == null) {

    strbuf.append("<tr><td > &nbsp;</td></tr>");

    continue;
   }

   strbuf.append("<tr>");
   int lastColNum = row.getLastCellNum();
   //int sumWidth=0;// 求头部的总width
   System.out.println("lastColNum:"+lastColNum);
   for (int colNum = 0; colNum < lastColNum; colNum++) {

    cell = row.getCell(colNum);
    int tdwidth = sheet.getColumnWidth(colNum) / 32;
    if (cell == null) {
     cell = row.createCell(colNum);
     cell.setCellValue("");
     // strbuf.append("<td>&nbsp;</td>");
     // continue;
    }
    
   
    
    HSSFCellStyle cellStyle = cell.getCellStyle();
    cellStyle.setWrapText(true);     
    cell.setCellStyle(cellStyle);
    String stringValue = getCellValue(cell);
    // String stringValue = this.getStringCellValue(cell);
    
    if (map[0].containsKey(rowNum + "," + colNum)) {
     String pointString = map[0].get(rowNum + "," + colNum);
     map[0].remove(rowNum + "," + colNum);
     int bottomeRow = Integer.valueOf(pointString.split(",")[0]);
     int bottomeCol = Integer.valueOf(pointString.split(",")[1]);
     int rowSpan = bottomeRow - rowNum + 1;
     int colSpan = bottomeCol - colNum + 1;
     strbuf.append("<td width=\""
       + getTdWidth(sheet, colNum, bottomeCol)
       + "\" rowspan=\"" + rowSpan + "\" colspan=\""
       + colSpan + "\" ");
    
     // System.out.print(getTdWidth(sheet,colNum,bottomeCol)+",");
    } else if (map[1].containsKey(rowNum + "," + colNum)) {

     map[1].remove(rowNum + "," + colNum);

     continue;

    } else {
     // System.out.print(tdwidth+",");
     if ("甲".equals(stringValue) || "乙".equals(stringValue)) {
      int tdwidths=tdwidth-10;
      strbuf.append("<th  filter-type=\"ddl\" width=\""
        + (tdwidths) + "\" ");
     } else if("&nbsp;".equals(stringValue)|| " ".equals(stringValue)) {
      strbuf.append("<td");
     }else{
      strbuf.append("<td width=\"" + tdwidth + "\" ");
      
     }
    
    }

    if (cellStyle != null) {

     short alignment = cellStyle.getAlignment();

     strbuf.append("align=\"" + convertAlignToHtml(alignment)
       + "\" ");

     short verticalAlignment = cellStyle.getVerticalAlignment();
     strbuf.append("valign=\""
       + convertVerticalAlignToHtml(verticalAlignment)
       + "\" ");

     HSSFFont hf = cellStyle.getFont(workbook);

     short boldWeight = hf.getBoldweight();

     short fontColor = hf.getColor();

     strbuf.append("style=\"");

     HSSFPalette palette = workbook.getCustomPalette(); // 类HSSFPalette用于求的颜色的国际标准形式

     HSSFColor hc = palette.getColor(fontColor);
     // System.out.println(boldWeight);
     // sb.append("font-weight:" + boldWeight + ";"); //字体加粗

     // sb.append("font-size: " + hf.getFontHeight()/2 + "%;");
     // //字体大小
     strbuf.append("font-size: " + hf.getFontHeightInPoints()
       + "pt;");
     strbuf.append("font-family:" + hf.getFontName() + ";");

     String fontColorStr = convertToStardColor(hc);

     if (fontColorStr != null && !"".equals(fontColorStr.trim())) {

      strbuf.append("color:" + fontColorStr + ";"); // 字体颜色
     }

     short bgColor = cellStyle.getFillForegroundColor();

     hc = palette.getColor(bgColor);

     String bgColorStr = convertToStardColor(hc);

     if (bgColorStr != null && !"".equals(bgColorStr.trim())) {

      strbuf.append("background-color:" + bgColorStr + ";"); // 背景颜色
     }

     short borderColor = cellStyle.getBottomBorderColor();
     short bordertop = cellStyle.getBorderTop();
     short borderleft = cellStyle.getBorderLeft();
     short borderright = cellStyle.getBorderRight();
     short borderbottom = cellStyle.getBorderBottom();
     short colorbottom = cellStyle.getBottomBorderColor();
     short colortop = cellStyle.getTopBorderColor();
     short colorleft = cellStyle.getLeftBorderColor();
     short colorright = cellStyle.getRightBorderColor();
     String borstyletop = this
       .convertBorderStyleToHtml(bordertop);
     String borstyleleft = this
       .convertBorderStyleToHtml(borderleft);
     String borstyleright = this
       .convertBorderStyleToHtml(borderright);
     String borstylebottom = this
       .convertBorderStyleToHtml(borderbottom);
     String bortopcolor = this
       .convertBorderColorToHtml(colortop);
     String borleftcolor = this
       .convertBorderColorToHtml(colorleft);
     String borrightcolor = this
       .convertBorderColorToHtml(colorright);
     String borbottomcolor = this
       .convertBorderColorToHtml(colorbottom);
     // System.out.print(borstyletop+"-"+borstyleleft+"-"+borstyleright+"-"+borstylebottom+",");

     strbuf.append("border-top:"
       + this.getBorderStyle(borstyletop, bortopcolor)
       + ";");
     strbuf.append("border-left:"
       + this.getBorderStyle(borstyleleft, borleftcolor)
       + ";");
     strbuf.append("border-right:"
       + this.getBorderStyle(borstyleright, borrightcolor)
       + ";");
     strbuf.append("border-bottom:"
       + this.getBorderStyle(borstylebottom,
         borbottomcolor) + ";");

     // sb.append("border:" +
     // this.convertBorderStyleToHtml(bordertop)+" "+
     // convertBorderColorToHtml(colorbottom)+ ";");
     // String

     hc = palette.getColor(borderColor);

     String borderColorStr = convertToStardColor(hc);

     if (borderColorStr != null
       && !"".equals(borderColorStr.trim())) {

     }

     strbuf.append("\" ");
    }

    strbuf.append(">");
    if (stringValue == null || "".equals(stringValue.trim())) {

     strbuf.append(" &nbsp; ");
    } else  {
                  // System.out.println("StringValue="+stringValue);
                   strbuf.append(stringValue.replaceAll("\\s *", "")+" ");
    /* strbuf.append(" "
       + stringValue.replace(String.valueOf((char) 160),
         "&nbsp;") + " ");*/

    }

    if ("甲".equals(stringValue) || "乙".equals(stringValue)) {
     strbuf.append("</th>");
    } else {
     strbuf.append("</td>");
    }

   }
   
    
   
  
   strbuf.append("</tr>");

   if (rowNum < rangenum) {
    // System.out.println("rowNumText="+rowNum);
    sb.append("$('#exceltitletable').append('" + strbuf.toString()
      + "');\n");
   } else if (rowNum == rangenum) {
    sb.append("$('#exceltable thead').append('" + strbuf.toString()
      + "');\n");
   } else {
    sb.append("$('#exceltable tbody').append('" + strbuf.toString()
      + "');\n");
   }

  }

  // sb.append("</table>\n");
  System.out.println("sumwidth="+this.getSumWidth());//取出总宽度的行数
  
  sb.append("var options1 = {\n");
  sb.append("    additionalFilterTriggers: [ ],\n");
  sb.append("    clearFiltersControls: [$('#deldata')],\n");
  sb.append("    matchingRow: function(state, tr, textTokens) {  \n");
  sb.append("      if (!state || !state.id) { return true; }\n");
  sb.append("var val =  tr.children('td:eq(2)').text();\n");
  sb.append("  switch (state.id) {   \n");
  sb.append("   default: return true;\n");
  sb.append("  }\n");
  sb.append(" }\n");
  sb.append("};\n");
  sb.append("$('#exceltable').tableFilter(options1);\n");
  sb.append("});\n");
  
 
  sb.append("</script>\n");

  // System.out.println(sb.toString());
  return sb;
 }

 @Override
 public String toString() {
  return "ExcelUtils []";
 }

 public int getTrWidth(HSSFWorkbook workbook, int sheetindex) {
  int trwidth = 0;
  Sheet sheet = workbook.getSheetAt(sheetindex);
  int lastRowNum = sheet.getLastRowNum();
  HSSFRow row = (HSSFRow) sheet.getRow(lastRowNum);
  if (row != null) {
   int lastColNum = row.getLastCellNum();
   for (int colNum = 0; colNum < lastColNum; colNum++) {
    HSSFCell cell = row.getCell(colNum);
    int tdwidth = sheet.getColumnWidth(colNum) / 32;
    trwidth = trwidth + tdwidth;
   }
  }
  return trwidth;
 }

 public StringBuffer excelToHtmlSource(HSSFWorkbook workbook, int sheetindex) {
  StringBuffer sb = new StringBuffer();

  Sheet sheet = workbook.getSheetAt(sheetindex);

  int lastRowNum = sheet.getLastRowNum();
  System.out.println("lastRowNum=" + lastRowNum);
  Map<String, String> map[] = getRowSpanColSpanMap(sheet);

  sb.append("<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n");

  HSSFRow row = null;

  HSSFCell cell = null;

  // System.out.println(sheet.getPhysicalNumberOfRows());
  for (int rowNum = sheet.getFirstRowNum(); rowNum <= lastRowNum; rowNum++) {
   row = (HSSFRow) sheet.getRow(rowNum);

   if (row == null) {

    sb.append("<tr><td > &nbsp;</td></tr>\n");

    continue;
   }

   sb.append("<tr>\n");

   int lastColNum = row.getLastCellNum();

   System.out.print(lastColNum + ":lastcolnum");

   System.out.print(rowNum + ":");
   for (int colNum = 0; colNum < lastColNum; colNum++) {

    cell = row.getCell(colNum);
    int tdwidth = sheet.getColumnWidth(colNum) / 32;
    if (cell == null) {
     sb.append("<td>&nbsp;</td>\n");

     continue;
    }

    String stringValue = getCellValue(cell);
    // System.out.print(colNum+"-");
    if (map[0].containsKey(rowNum + "," + colNum)) {

     String pointString = map[0].get(rowNum + "," + colNum);

     map[0].remove(rowNum + "," + colNum);

     int bottomeRow = Integer.valueOf(pointString.split(",")[0]);

     int bottomeCol = Integer.valueOf(pointString.split(",")[1]);

     int rowSpan = bottomeRow - rowNum + 1;

     int colSpan = bottomeCol - colNum + 1;

     sb.append("<td rowspan= '" + rowSpan + "' colspan= '"
       + colSpan + "' ");

    } else if (map[1].containsKey(rowNum + "," + colNum)) {

     map[1].remove(rowNum + "," + colNum);

     continue;

    } else {
     // System.out.print(tdwidth+",");
     sb.append("<td width='" + tdwidth + "' ");
    }

    HSSFCellStyle cellStyle = cell.getCellStyle();
    cellStyle.setWrapText(true);   

    if (cellStyle != null) {

     short alignment = cellStyle.getAlignment();

     sb.append("align='" + convertAlignToHtml(alignment) + "' ");

     short verticalAlignment = cellStyle.getVerticalAlignment();

     sb.append("valign='"
       + convertVerticalAlignToHtml(verticalAlignment)
       + "' ");

     HSSFFont hf = cellStyle.getFont(workbook);

     short boldWeight = hf.getBoldweight();

     short fontColor = hf.getColor();

     sb.append("style='");

     HSSFPalette palette = workbook.getCustomPalette(); // 类HSSFPalette用于求的颜色的国际标准形式

     HSSFColor hc = palette.getColor(fontColor);
     // System.out.println(boldWeight);
     // sb.append("font-weight:" + boldWeight + ";"); //字体加粗

     // sb.append("font-size: " + hf.getFontHeight()/2 + "%;");
     // //字体大小
     sb.append("font-size: " + hf.getFontHeightInPoints()
       + "pt;");
     sb.append("font-family:" + hf.getFontName() + ";");

     String fontColorStr = convertToStardColor(hc);

     if (fontColorStr != null && !"".equals(fontColorStr.trim())) {

      sb.append("color:" + fontColorStr + ";"); // 字体颜色
     }

     short bgColor = cellStyle.getFillForegroundColor();

     hc = palette.getColor(bgColor);

     String bgColorStr = convertToStardColor(hc);

     if (bgColorStr != null && !"".equals(bgColorStr.trim())) {

      sb.append("background-color:" + bgColorStr + ";"); // 背景颜色
     }

     short borderColor = cellStyle.getBottomBorderColor();
     short bordertop = cellStyle.getBorderTop();
     short borderleft = cellStyle.getBorderLeft();
     short borderright = cellStyle.getBorderRight();
     short borderbottom = cellStyle.getBorderBottom();
     short colorbottom = cellStyle.getBottomBorderColor();
     short colortop = cellStyle.getTopBorderColor();
     short colorleft = cellStyle.getLeftBorderColor();
     short colorright = cellStyle.getRightBorderColor();
     String borstyletop = this
       .convertBorderStyleToHtml(bordertop);
     String borstyleleft = this
       .convertBorderStyleToHtml(borderleft);
     String borstyleright = this
       .convertBorderStyleToHtml(borderright);
     String borstylebottom = this
       .convertBorderStyleToHtml(borderbottom);
     String bortopcolor = this
       .convertBorderColorToHtml(colortop);
     String borleftcolor = this
       .convertBorderColorToHtml(colorleft);
     String borrightcolor = this
       .convertBorderColorToHtml(colorright);
     String borbottomcolor = this
       .convertBorderColorToHtml(colorbottom);
     // System.out.print(borstyletop+"-"+borstyleleft+"-"+borstyleright+"-"+borstylebottom+",");

     sb.append("border-top:"
       + this.getBorderStyle(borstyletop, bortopcolor)
       + ";");
     sb.append("border-left:"
       + this.getBorderStyle(borstyleleft, borleftcolor)
       + ";");
     sb.append("border-right:"
       + this.getBorderStyle(borstyleright, borrightcolor)
       + ";");
     sb.append("border-bottom:"
       + this.getBorderStyle(borstylebottom,
         borbottomcolor) + ";");

     // sb.append("border:" +
     // this.convertBorderStyleToHtml(bordertop)+" "+
     // convertBorderColorToHtml(colorbottom)+ ";");
     // String

     hc = palette.getColor(borderColor);

     String borderColorStr = convertToStardColor(hc);

     if (borderColorStr != null
       && !"".equals(borderColorStr.trim())) {

      // sb.append("border-color:" + borderColorStr + ";");
      // //边框颜色
     }

     sb.append("' ");
    }

    sb.append(">");

    if (stringValue == null || "".equals(stringValue.trim())) {

     sb.append(" &nbsp; ");
    } else {

     sb.append(stringValue.replace(String.valueOf((char) 160),
       "&nbsp;"));

    }

    sb.append("</td>\n");

   }
   // System.out.println("");
   sb.append("</tr>\n");
  }

  sb.append("</table>\n");

  // System.out.println(sb.toString());
  return sb;
 }

 public static String getHex(String strHex) {
  if (strHex.length() > 0) {
   String[] a = strHex.split(":");
   strHex = "";
   for (int n = 0; n < a.length; n++) {
    if (a[n].length() > 0) {
     if (a[n].length() < 2) {
      strHex += "0" + a[n];
     } else

     {
      strHex += a[n].substring(0, 2);
     }
    }
   }
  }
  return strHex.length() > 0 ? strHex : null;

 }

 @SuppressWarnings("unchecked")
 private Map<String, String>[] getRowSpanColSpanMap(Sheet sheet) {

  Map<String, String> map0 = new HashMap<String, String>();
  Map<String, String> map1 = new HashMap<String, String>();

  int mergedNum = sheet.getNumMergedRegions();
  // System.out.println("mergedNum="+mergedNum);
  CellRangeAddress range = null;

  for (int i = 0; i < mergedNum; i++) {

   range = sheet.getMergedRegion(i);

   int topRow = range.getFirstRow();

   int topCol = range.getFirstColumn();

   int bottomRow = range.getLastRow();

   int bottomCol = range.getLastColumn();

   map0.put(topRow + "," + topCol, bottomRow + "," + bottomCol);

   // System.out.println(topRow + "," + topCol + "," + bottomRow + ","
   // + bottomCol);

   int tempRow = topRow;

   while (tempRow <= bottomRow) {

    int tempCol = topCol;

    while (tempCol <= bottomCol) {

     map1.put(tempRow + "," + tempCol, "");

     tempCol++;
    }

    tempRow++;
   }

   map1.remove(topRow + "," + topCol);

  }

  Map[] map = { map0, map1 };

  return map;
 }

 private String convertAlignToHtml(short alignment) {

  String align = "left";

  switch (alignment) {

  case HSSFCellStyle.ALIGN_LEFT:
   align = "left";
   break;
  case HSSFCellStyle.ALIGN_CENTER:
   align = "center";
   break;
  case HSSFCellStyle.ALIGN_RIGHT:
   align = "right";
   break;

  default:
   break;
  }

  return align;
 }

 private String getBorderStyle(String bortype, String borcolor) {
  String borstyle = "";
  if ("thin".equals(bortype)) {
   borstyle = "1px solid " + borcolor;
  } else if ("medium".equals(bortype)) {
   borstyle = "2px solid " + borcolor;
  } else if ("double".equals(bortype)) {
   borstyle = "double solid " + borcolor;
  } else if ("dotted".equals(bortype)) {
   borstyle = "1px dotted " + borcolor;
  } else if ("dashed".equals(bortype)) {
   borstyle = "1px dashed " + borcolor;
  }
  return borstyle;
 }

 private String convertBorderStyleToHtml(short bordertype) {
  String type = "none";
  switch (bordertype) {

  case HSSFCellStyle.BORDER_THIN:
   type = "thin";
   break;
  case HSSFCellStyle.BORDER_DOTTED:
   type = "dotted";
   break;
  case HSSFCellStyle.BORDER_DASHED:
   type = "dashed";
   break;
  case HSSFCellStyle.BORDER_NONE:
   type = "none";
   break;
  case HSSFCellStyle.BORDER_MEDIUM:
   type = "medium";
   break;
  case HSSFCellStyle.BORDER_DOUBLE:
   type = "double";
   break;

  default:
   break;
  }

  return type;
 }

 private String convertBorderColorToHtml(short bordercolor) {
  String type = "black";

  switch (bordercolor) {
  case HSSFColor.BLACK.index:
   type = "black";
   break;
  case HSSFColor.BLUE.index:
   type = "blue";
   break;
  case HSSFColor.RED.index:
   type = "red";
   break;

  default:
   break;
  }

  return type;
 }

 private String convertVerticalAlignToHtml(short verticalAlignment) {

  String valign = "middle";

  switch (verticalAlignment) {

  case HSSFCellStyle.VERTICAL_BOTTOM:
   valign = "bottom";
   break;
  case HSSFCellStyle.VERTICAL_CENTER:
   valign = "center";
   break;
  case HSSFCellStyle.VERTICAL_TOP:
   valign = "top";
   break;
  default:
   break;
  }

  return valign;
 }

 private String convertToStardColor(HSSFColor hc) {

  StringBuffer sb = new StringBuffer("");

  if (hc != null) {

   if (HSSFColor.AUTOMATIC.index == hc.getIndex()) {

    return null;
   }

   sb.append("#");

   for (int i = 0; i < hc.getTriplet().length; i++) {

    sb
      .append(fillWithZero(Integer.toHexString(hc
        .getTriplet()[i])));
   }
  }

  return sb.toString();
 }

 private String fillWithZero(String str) {

  if (str != null && str.length() < 2) {

   return "0" + str;
  }
  return str;
 }

 /**
  * 获取Cell的内容
  *
  * @param cell
  * @return
  */
 public String getStringCellValue(HSSFCell cell) {
  String cellvalue = "";
  if (cell == null) {
   return "";
  }
  switch (cell.getCellType()) {
  case HSSFCell.CELL_TYPE_STRING:
   cellvalue = cell.getStringCellValue();
   break;
  case HSSFCell.CELL_TYPE_NUMERIC:
   cellvalue = String.valueOf(cell.getNumericCellValue());
   break;
  case HSSFCell.CELL_TYPE_BOOLEAN:
   cellvalue = String.valueOf(cell.getBooleanCellValue());
   break;
  case HSSFCell.CELL_TYPE_BLANK:
   cellvalue = "";
   break;
  default:
   cellvalue = "";
   break;
  }
  if (!StringUtils.hasText(cellvalue)) {
   return "";
  }
  return cellvalue;
 }

 private String getCellValue(HSSFCell cell) {

  switch (cell.getCellType()) {

  case HSSFCell.CELL_TYPE_NUMERIC:

   DecimalFormat format = new DecimalFormat("#0.##");

   return format.format(cell.getNumericCellValue());
   // return String.valueOf(cell.getNumericCellValue());

  case HSSFCell.CELL_TYPE_STRING:

   return cell.getStringCellValue();

   // case HSSFCell.CELL_TYPE_FORMULA:
   //   
   // return cell.getCellFormula();

  default:
   return "";
  }
 }

 /**
  * 读取excel
  *
  * @param filepath
  *            excel文件地址
  * @return HSSFWorkbook
  */
 public HSSFWorkbook readExcelFile(String filepath) {
  HSSFWorkbook workbook = null;
  try {
   FileInputStream input = new FileInputStream(new File(filepath));
   POIFSFileSystem fs = new POIFSFileSystem(input);
   workbook = new HSSFWorkbook(fs);
  } catch (Exception e) {
   e.printStackTrace();
  }
  return workbook;
 }

 /**
  * 获取某Sheet,第一行的内容
  *
  * @param workbook
  * @param sheetindex
  * @return
  */
 public String getFirstRowContent(HSSFWorkbook workbook, int sheetindex) {
  String exceltitle = "";
  if (workbook != null) {
   HSSFSheet sheet = workbook.getSheetAt(sheetindex);
   int firstrownum = sheet.getFirstRowNum();
   HSSFRow row = sheet.getRow(firstrownum);
   short fcellnum = row.getFirstCellNum();
   short lcellnum = row.getLastCellNum();
   for (int j = fcellnum; j < lcellnum; j++) {
    HSSFCell cell = row.getCell(j);
    exceltitle += getStringCellValue(cell);
   }
  }
  return exceltitle;
 }

 public CellRangeAddress getRange(HSSFSheet sheet) {
  if (sheet != null) {
   int rangenum = sheet.getNumMergedRegions();
   for (int m = 0; m < rangenum; m++) {
    CellRangeAddress range = sheet.getMergedRegion(m);
   }
  }
  return null;
 }

 public List getRangeRows(HSSFSheet sheet) {
  if (sheet != null) {
   int rangenum = sheet.getNumMergedRegions();//找到当前sheet单元格中共有多少个合并区域 
   //System.out.println("RangenNum="+rangenum);
   ArrayList list = new ArrayList();
   if (rangenum > 0) {
    for (int i = 0; i < rangenum; i++) {
     CellRangeAddress range = sheet.getMergedRegion(i);//一个合并单元格代表 CellRangeAddress  
     list.add(range.getFirstRow());
     list.add(range.getLastRow());
     list.add(range.getLastColumn());
     list.add(range.getFirstColumn());
    
     // range.
     // range.isInRange(rowInd, colInd)()

    }
    Collections.sort(list);
    this.removeDuplicateWithOrder(list);
    return list;
   }
  }
  return null;
 }
 
 public int getSumWidth(int sum){
  return sum;
 }

 /** List order maintained **/
 public static void removeDuplicateWithOrder(ArrayList arlList) {
  Set set = new HashSet();
  List newList = new ArrayList();
  for (Iterator iter = arlList.iterator(); iter.hasNext();) {
   Object element = iter.next();
   if (set.add(element))
    newList.add(element);
  }
  arlList.clear();
  arlList.addAll(newList);
 }

 public java.awt.Color toAWTColor(int R, int G, int B, int A) {
  return new java.awt.Color(R, G, B, A);
 }

 public int toRGB(int R, int G, int B) {
  return R << 16 | G << 8 | B;
 }

 public String getTdString(HSSFCell cell) {
  String tdstr = "";

  return tdstr;
 }
 
 public int getSumWidth() {
  return sumWidth;
 }

 public void setSumWidth(int sumWidth) {
  this.sumWidth = sumWidth;
 }


}

1
2
分享到:
评论

相关推荐

    JAVA poi 做EXCEL导出(包含图片) 完整版

    本教程将详细介绍如何使用JAVA POI库来创建一个包含图片的完整Excel导出功能。 首先,你需要在项目中引入Apache POI依赖。如果你使用的是Maven,可以在pom.xml文件中添加以下依赖: ```xml &lt;groupId&gt;org.apache....

    Excel poi java jsp

    在Java Web开发中,"Excel poi java jsp"是一个常见的技术组合,用于处理Excel文件的导入和导出功能。此组合利用Apache POI库来操作Excel文件,通过Servlet作为服务器端处理逻辑,而JSP则作为用户界面进行交互。下面...

    poi读取excel并输出到jsp页面

    标题中的“poi读取excel并输出到jsp页面”是指使用Apache POI库来处理Microsoft Excel文件,并将数据在JavaServer Pages (JSP) 页面上显示的技术。Apache POI 是一个开源项目,它允许开发者创建、修改和显示MS ...

    java POI导出excel

    这个是利用POI导出excel的源码,需要导入poi包,然后把jsp和action的代码拷贝进去就可以直接运行,很基础的代码,很适合初学者学习。 POI可以自己定义导出excel格式的数据,实例就是这样弄的,希望对初学者有帮助。

    java poi excel上传 下载

    Java POI 是一个开源库,专门用于处理Microsoft Office格式的文件,如Excel、Word和PowerPoint。在Java中,利用Apache POI库可以方便地进行Excel文件的读写操作,从而实现Excel数据的上传和下载功能。这个项目提供的...

    java 利用POI 导入导出Excel

    前几天项目上需要加上导入导出,在网上找了一下,么有...于是自己写,源码里所需要的jar都有,从jsp界面进行Excel的导入导出,并可用于上传和下载。如有所用,喜不自禁,分享,开源的意义。 写的不是特别好,不喜勿喷!

    jsp利用POI生成Excel并在页面中导出的示例.docx

    总结起来,本示例展示了如何在JSP中使用Apache POI库创建Excel文件并直接导出。这包括配置`web.xml`以支持Excel MIME类型,编写`download.jsp`页面以设置响应头并调用生成Excel的JavaBean,以及编写`WriteExcel.java...

    java POI生成word.zip

    - Java POI 是一套API,用于处理Microsoft Office格式的文件,如Excel (.xls), Word (.doc), PowerPoint (.ppt)等。 - 它提供了一种与Office格式兼容的方式来操作这些文件,使得开发者可以在不依赖Microsoft ...

    java j2ee poi xsl excel 文档操作 包括上传 下载

    在这个场景中,我们关注的是如何使用Java J2EE来处理Excel文档,特别是通过Apache POI库进行读写操作,并涉及到XSL转换。 Apache POI是一个开源项目,专门用于读取和写入Microsoft Office格式的文件,包括Excel(....

    jsp使用poi生成有格式的excel

    标题中的"jsp使用poi生成有格式的excel"指的是使用Java Server Pages (JSP) 技术,结合Apache POI库来创建带有特定格式(如样式、合并单元格、打印设置等)的Excel文件。Apache POI是Apache软件基金会的一个开源项目...

    SpringMvc+POI 处理Excel的导入操作

    package com.poiexcel.util; import java.io.IOException; import java.io.InputStream; import java.text.DecimalFormat; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.List...

    jsp+poi导出excel.docx

    本文档提供了一种使用jsp和poi来导出excel文件的解决方案,包括修改配置文件、创建jsp文件和java类文件等步骤。该解决方案可以帮助开发者快速实现excel文件的导出功能。 知识点: 1. 使用poi组件来导出excel文件 2...

    jsp中使用poi导入导出Excel

    在Java Web开发中,JSP(JavaServer Pages)是一种用于创建动态网页的技术,而Apache POI则是一个流行的库,用于处理Microsoft Office格式的文件,包括Excel。本教程将深入讲解如何在JSP中利用POI库实现Excel的导入...

    poi +jsp 实现excel的上传下载的小例子

    标题中的“poi+jsp 实现excel的上传下载的小例子”是指使用Apache POI库与Java Server Pages(JSP)技术来处理Excel文件的上传和下载功能。Apache POI是一个流行的开源项目,它允许开发者在Java应用程序中创建、修改...

    使用JSP+jqueryUI+java Servlet通过Apache POI实现Excel导入导出

    使用Apache POI,我们可以在Java中方便地操作Excel文件,读取单元格内容,修改样式,甚至创建新的工作簿和工作表。 具体实现步骤如下: 1. 创建JSP页面,包含一个文件上传的表单,使用jQuery UI的文件输入组件,...

    poi解析jsp上传的excel文件并导入mysql(支持xls和xlsx)优化版

    首先,POI是Apache软件基金会的Java API,用于处理Microsoft Office格式的文件,如Excel。在这个场景中,POI被用来解析上传的Excel文件,无论是.xls(Excel 97-2003格式)还是.xlsx(Excel 2007及以后的XML格式)。...

    java jsp 上传 下载 excel poi

    总结起来,结合Java JSP、Apache POI和适当的文件上传处理库,我们可以构建一个功能齐全的系统,允许用户上传Excel文件,系统将文件保存在服务器上,然后用户可以选择下载。同时,通过Apache POI,我们可以轻松地...

    java中读取excel,并在jsp中以表格展现

    Apache POI是一个广泛使用的Java库,它提供了对Microsoft Office格式(包括Excel)的支持。安装Apache POI后,你可以使用它的API来读取Excel文件: 1. **导入所需库**:在你的Java代码中,确保引入了Apache POI的...

    Java对Excel表格的操作

    本章节将详细介绍如何使用Java技术,特别是JSP(Java Server Pages),结合第三方库来处理Excel文件。 #### 1.1 JSP操作Excel工具汇总 在Java生态中,处理Excel文档有几种流行的开源解决方案,其中最为知名的有两...

    jsp+jspsmart上传+poi3.8读取excel2007+jxl读取excel2003

    综上所述,这个解决方案的核心是使用JSP作为前端交互界面,jspsmart处理文件上传,然后在服务器端使用POI读取Excel 2007以上的.xlsx文件,jxl处理Excel 2003及以下的.xls文件。这种组合方式确保了对不同版本Excel...

Global site tag (gtag.js) - Google Analytics