2014年4月1日周二 晴--关于4G的某任务,Excel读取

 今天接到一个任务是12个Excel文件要Copy到JSP文件中,要我”ACV“吗?一个没复制完就受不了这种无聊的工作,果断换别的方式。
用程序解决!但是我不知道怎样按行去读Excel表格的数据,百度一下吧。文件读取好像答案不是我想要的结果。好吧,搜一下Java读取Excel吧,这个是我要的方法了。
import java.io.File;
import jxl.Sheet;
import jxl.Workbook;
/**
 * 注意:
1.有空能输出空列、空行
 * 2.编码问题
 * */
public class ReadExcel {
 public static void main(String[] args) throws Exception{
  Workbook workbook = Workbook.getWorkbook(new File("F:/asia/excelorder/panjin.xls"));//文件路径
  Sheet sheet[] = workbook.getSheets();
  String lab = null;
  System.out.println("<table cellspacing=\"0\" cellpadding=\"0\" class=\"info_4g_table4\">");
  for(int a=0;a<sheet.length;a++){
   for(int i=0;i<sheet[a].getRows();i++){
    System.out.print("<tr>");
    for(int j=0;j<sheet[a].getColumns();j++){
     lab = sheet[a].getCell(j,i).getContents();
     if(null!=lab&&!lab.equals("")){
      if(i==0){
       System.out.print("<th>"+lab+"</th>");
      }else{
       System.out.print("<td>"+lab+"</td>");
      }
     }
    }
    System.out.println("</tr>");
   }
  }
  System.out.print("</table>");
 }

暂时用这个 程序先完成任务再说,本来打算回来讲代码写一下完善一下,计划赶不上变化呀,只能改天了。悲催的上班要在路上消耗1:30小时,下班回家吃完饭9:00多了。
2014年4月3日 周四 晴
今天又查了一些东西,补充完整Excel文件读取。下载jexcelapi或者poiapi会有Demo和相关文档。
使用POI存在的问题:
1、整数数字变成了浮点类型;
2、代码生成table的属性时,浏览器兼容性问题,在FireFox里乱了,IE8、Google Chrome没问题,呵~呵~
<table width="100%" style="border:1px solid #000;border-width:1px 0 0 1px;margin:2px 0 2px 0;border-collapse:collapse;">
<tr height="28" style="border:1px solid #000;border-width:0 1px 1px 0;margin:2px 0 2px 0;">
<td style="border:1px solid #000; border-width:0 1px 1px 0;margin:2px 0 2px 0;  background-color:#99ccff;  color:#000000;  font-weight:700;  font-size: 100%;" align="center" valign="center" width="58"  colspan="0" rowspan="0">序号</td>
<td style="border:1px solid #000; border-width:0 1px 1px 0;margin:2px 0 2px 0;  background-color:#99ccff;  color:#000000;  font-weight:700;  font-size: 100%;" align="center" valign="center" width="101"  colspan="0" rowspan="0">区域</td>
<td style="border:1px solid #000; border-width:0 1px 1px 0;margin:2px 0 2px 0;  background-color:#99ccff;  color:#000000;  font-weight:700;  font-size: 100%;" align="center" valign="center" width="144"  colspan="0" rowspan="0">覆盖范围</td>
</tr>
<tr height="17" style="border:1px solid #000;border-width:0 1px 1px 0;margin:2px 0 2px 0;">
<td style="border:1px solid #000; border-width:0 1px 1px 0;margin:2px 0 2px 0;  color:#000000;  font-weight:400;  font-size: 110%;" align="center" valign="center" width="58"  colspan="0" rowspan="0">1.0</td>
<td style="border:1px solid #000; border-width:0 1px 1px 0;margin:2px 0 2px 0;  color:#000000;  font-weight:400;  font-size: 110%;" align="center" valign="center" width="101"  colspan="0" rowspan="0">铁东区</td>
<td style="border:1px solid #000; border-width:0 1px 1px 0;margin:2px 0 2px 0;  color:#000000;  font-weight:400;  font-size: 110%;" align="center" valign="center" width="144"  colspan="0" rowspan="0">铁东园林街道</td>
</tr>……
</table>
原Excel表格图片
生成的表格,在IE中的效果
图片
在FireFox里的效果
图片
这鬼样子!
package test;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.math.BigDecimal;
import java.text.SimpleDateFormat;
import java.util.Date;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFDateUtil;
import org.apache.poi.hssf.usermodel.HSSFPalette;
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.ss.util.CellRangeAddress;
public class OperateExcel {
 /**
  * SID.
  */
 private static final long serialVersionUID = -8344971443770122206L;
 /**
  * 只读取Excel表格的数据,使用css设置table的样式
  * @param excelFileName excel文件名
  * @param tableClass table的css样式
  * @return
  * @throws Exception
  * */
 public StringBuffer read(String excelFileName, String tableClass) throws Exception {
  HSSFSheet sheet = null;
  StringBuffer lsb = new StringBuffer();
  try {
   HSSFWorkbook workbook = new HSSFWorkbook(new FileInputStream(excelFileName)); // 获整个Excel
   for (int sheetIndex = 0; sheetIndex < workbook.getNumberOfSheets(); sheetIndex++) {
    sheet = workbook.getSheetAt(sheetIndex);// 获所有的sheet
    if (workbook.getSheetAt(sheetIndex) != null) {
     sheet = workbook.getSheetAt(sheetIndex);// 获得不为空的这个sheet
     if (sheet != null) {
      int firstRowNum = sheet.getFirstRowNum(); // 第一行
      int lastRowNum = sheet.getLastRowNum(); // 最后一行
      // 构造Table
      lsb.append("<table class=\"" + tableClass + "\">\n");
      for (int rowNum = firstRowNum; rowNum <= lastRowNum; rowNum++) {
       if (sheet.getRow(rowNum) != null) {// 如果行不为空,
        HSSFRow row = sheet.getRow(rowNum);
        short firstCellNum = row.getFirstCellNum(); // 该行的第一个单元格
        short lastCellNum = row.getLastCellNum(); // 该行的最后一个单元格
        lsb.append("<tr>");
        for (short cellNum = firstCellNum; cellNum <= lastCellNum; cellNum++) { // 循环该行的每一个单元格
         HSSFCell cell = row.getCell(cellNum);
         if (cell != null) {
          if (cell.getCellType() == HSSFCell.CELL_TYPE_BLANK) {
           continue;
          }else {
           if(rowNum == firstRowNum){
            StringBuffer tdStyle =new StringBuffer("<th>");
            lsb.append(tdStyle);
            lsb.append(getCellValue(cell)+"</th>");
           }else{
            StringBuffer tdStyle =new StringBuffer("<td>");
            lsb.append(tdStyle);
            lsb.append(getCellValue(cell)+"</td>");
           }
          }
         }
        }
        lsb.append("</tr>\n");
       }
      }
      lsb.append("</table>\n");
     }
    }
   }
  } catch (FileNotFoundException e) {
   throw new Exception("文件 " + excelFileName + " 没有找到!");
  } catch (IOException e) {
   throw new Exception("文件 " + excelFileName + " 处理错误("
     + e.getMessage() + ")!");
  }
  return lsb;
 }
 /**
  * 读取 Excel表格原样输出
  * @param excelFileName Excel文件名
  * @return
  * @throws Exception
  */
 public StringBuffer read(String excelFileName) throws Exception {
  HSSFSheet sheet = null;
  StringBuffer lsb = new StringBuffer();
  try {
   HSSFWorkbook workbook = new HSSFWorkbook(new FileInputStream(excelFileName)); // 获整个Excel
   for (int sheetIndex = 0; sheetIndex < workbook.getNumberOfSheets(); sheetIndex++) {
    sheet = workbook.getSheetAt(sheetIndex);// 获所有的sheet
    //String sheetName = workbook.getSheetName(sheetIndex); // sheetName
    if (workbook.getSheetAt(sheetIndex) != null) {
     sheet = workbook.getSheetAt(sheetIndex);// 获得不为空的这个sheet
     if (sheet != null) {
      int firstRowNum = sheet.getFirstRowNum(); // 第一行
      int lastRowNum = sheet.getLastRowNum(); // 最后一行
      // 构造Table
      lsb.append("<table width=\"100%\" style=\"border:1px solid #000;border-width:1px 0 0 1px;margin:2px 0 2px 0;border-collapse:collapse;\">\n");
      for (int rowNum = firstRowNum; rowNum <= lastRowNum; rowNum++) {
       if (sheet.getRow(rowNum) != null) {// 如果行不为空,
        HSSFRow row = sheet.getRow(rowNum);
        short firstCellNum = row.getFirstCellNum(); // 该行的第一个单元格
        short lastCellNum = row.getLastCellNum(); // 该行的最后一个单元格
        int height = (int) (row.getHeight()/15.625); // 行的高度
        lsb.append("<tr height=\""+height+"\" style=\"border:1px solid #000;border-width:0 1px 1px 0;margin:2px 0 2px 0;\">");
        for (short cellNum = firstCellNum; cellNum <= lastCellNum; cellNum++) { // 循环该行的每一个单元格
         HSSFCell cell = row.getCell(cellNum);
         if (cell != null) {
          if (cell.getCellType() == HSSFCell.CELL_TYPE_BLANK) {
           continue;
          }else {
           StringBuffer tdStyle =new StringBuffer("<td style=\"border:1px solid #000; border-width:0 1px 1px 0;margin:2px 0 2px 0; ");
           HSSFCellStyle cellStyle = cell.getCellStyle();
           HSSFPalette palette = workbook.getCustomPalette(); //类HSSFPalette用于求颜色的国际标准形式
           HSSFColor hColor = palette.getColor(cellStyle.getFillForegroundColor());
           HSSFColor hColor2 = palette.getColor(cellStyle.getFont(workbook).getColor());
           
           String bgColor = convertToStardColor(hColor);//背景颜色
           short boldWeight = cellStyle.getFont(workbook).getBoldweight(); // 字体粗细
           short fontHeight = (short) (cellStyle.getFont(workbook).getFontHeight() / 2); // 字体大小
           String fontColor = convertToStardColor(hColor2); // 字体颜色
           if(bgColor != null && !"".equals(bgColor.trim())){
            tdStyle.append(" background-color:" + bgColor + "; ");
           }
           if(fontColor != null && !"".equals(fontColor.trim())) {
            tdStyle.append(" color:" + fontColor + "; ");
           }
           tdStyle.append(" font-weight:" + boldWeight + "; ");
           tdStyle.append(" font-size: " + fontHeight + "%;");
           lsb.append(tdStyle + "\"");
           
           int width = (int) (sheet.getColumnWidth(cellNum)/ 35.7); //
           int cellReginCol = getMergerCellRegionCol(sheet,rowNum, cellNum); // 合并的列(solspan)
           int cellReginRow = getMergerCellRegionRow(sheet, rowNum, cellNum);// 合并的行(rowspan)
           String align = convertAlignToHtml(cellStyle.getAlignment()); //
           String vAlign = convertVerticalAlignToHtml(cellStyle.getVerticalAlignment());
             
           lsb.append(" align=\"" + align + "\" valign=\""+vAlign+"\" width=\"" + width + "\" ");
           lsb.append(" colspan=\"" + cellReginCol + "\" rowspan=\""+cellReginRow+"\"");
           lsb.append(">"+getCellValue(cell)+"</td>");
          }
         }
        }
        lsb.append("</tr>\n");
       }
      }
      lsb.append("</table>\n");
     }
    }
   }
  } catch (FileNotFoundException e) {
   throw new Exception("文件 " + excelFileName + " 没有找到!");
  } catch (IOException e) {
   throw new Exception("文件 " + excelFileName + " 处理错误("
     + e.getMessage() + ")!");
  }
  return lsb;
 }

 /**
  * 取得单元格的值
  * @param cell
  * @return
  * @throws IOException
  */
 private static Object getCellValue(HSSFCell cell) throws IOException {
  Object value = "";
  if (cell.getCellType() == HSSFCell.CELL_TYPE_STRING) {
   value = cell.getRichStringCellValue().toString();
  } else if (cell.getCellType() == HSSFCell.CELL_TYPE_NUMERIC) {
   if (HSSFDateUtil.isCellDateFormatted(cell)) {
    Date date = cell.getDateCellValue();
    SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
    value = sdf.format(date);
   } else {
    double value_temp = (double) cell.getNumericCellValue();
    BigDecimal bd = new BigDecimal(value_temp);
    BigDecimal bd1 = bd.setScale(3, bd.ROUND_HALF_UP);
    value = bd1.doubleValue();
    
    /*
    DecimalFormat format = new DecimalFormat("#0.###");
    value = format.format(cell.getNumericCellValue());
    */
   }
  }
  if (cell.getCellType() == HSSFCell.CELL_TYPE_BLANK) {
   value = "";
  }
  return value;
 }
 
 /**
  * 判断单元格在不在合并单元格范围内,如果是,获取其合并的列数。
  * @param sheet 工作表
  * @param cellRow 被判断的单元格的行号
  * @param cellCol 被判断的单元格的列号
  * @return
  * @throws IOException
  */
 private static int getMergerCellRegionCol(HSSFSheet sheet, int cellRow,int cellCol) throws IOException {
  int retVal = 0;
  int sheetMergerCount = sheet.getNumMergedRegions();
  for (int i = 0; i < sheetMergerCount; i++) {
   CellRangeAddress cra = (CellRangeAddress) sheet.getMergedRegion(i);
   int firstRow = cra.getFirstRow();  // 合并单元格CELL起始行
   int firstCol = cra.getFirstColumn(); // 合并单元格CELL起始列
   int lastRow = cra.getLastRow(); // 合并单元格CELL结束行
   int lastCol = cra.getLastColumn(); // 合并单元格CELL结束列
   if (cellRow >= firstRow && cellRow <= lastRow) { // 判断该单元格是否是在合并单元格中
    if (cellCol >= firstCol && cellCol <= lastCol) {
     retVal = lastCol - firstCol+1; // 得到合并的列数
     break;
    }
   }
  }
  return retVal;
 }
 
 /**
  * 判断单元格是否是合并的单格,如果是,获取其合并的行数。
  * @param sheet 表单
  * @param cellRow 被判断的单元格的行号
  * @param cellCol 被判断的单元格的列号
  * @return
  * @throws IOException
  */
 private static int getMergerCellRegionRow(HSSFSheet sheet, int cellRow,int cellCol) throws IOException {
  int retVal = 0;
  int sheetMergerCount = sheet.getNumMergedRegions();
  for (int i = 0; i < sheetMergerCount; i++) {
   CellRangeAddress cra = (CellRangeAddress) sheet.getMergedRegion(i);
   int firstRow = cra.getFirstRow();  // 合并单元格CELL起始行
   int firstCol = cra.getFirstColumn(); // 合并单元格CELL起始列
   int lastRow = cra.getLastRow(); // 合并单元格CELL结束行
   int lastCol = cra.getLastColumn(); // 合并单元格CELL结束列
   if (cellRow >= firstRow && cellRow <= lastRow) { // 判断该单元格是否是在合并单元格中
    if (cellCol >= firstCol && cellCol <= lastCol) {
     retVal = lastRow - firstRow + 1; // 得到合并的行数
     break;
    }
   }
  }
  return retVal;
 }
 
 /**
  * 单元格背景色转换
  * @param hc
  * @return
  */
 private String convertToStardColor(HSSFColor hc) {
  StringBuffer sb = new StringBuffer("");
  if (hc != null) {
   int a = HSSFColor.AUTOMATIC.index;
   int b = hc.getIndex();
   if (a == b) {
    return null;
   }
   sb.append("#");
   for (int i = 0; i < hc.getTriplet().length; i++) {
    String str ;
    String str_tmp = Integer.toHexString(hc.getTriplet()[i]);
    if (str_tmp != null && str_tmp.length() < 2) {
     str = "0" + str_tmp;
    }else {
     str = str_tmp;
    }
    sb.append(str);
   }
  }
  return sb.toString();
 }
 
 /**
  * 单元格水平对齐
  * @param alignment
  * @return
  */
 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;
 }
 
 /**
  * 单元格垂直对齐
  * @param verticalAlignment
  * @return
  */
 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;
 }
 
 public static void main(String[] args){
  OperateExcel operateExcel = new OperateExcel();
  String excelFileName = "F:/asia/excel/anshan.xls";
  String tableCss = "info_4g_table4";
  try{
   System.out.println(operateExcel.read(excelFileName));
   System.out.println(operateExcel.read(excelFileName, tableCss));
  }catch(Exception e){
   e.printStackTrace();
  }
 }
}
package test;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.math.BigDecimal;
import java.text.SimpleDateFormat;
import java.util.Date;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFDateUtil;
import org.apache.poi.hssf.usermodel.HSSFPalette;
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.ss.util.CellRangeAddress;
public class OperateExcel {
 /**
  * SID.
  */
 private static final long serialVersionUID = -8344971443770122206L;
 /**
  * 只读取Excel表格的数据,使用css设置table的样式
  * @param excelFileName excel文件名
  * @param tableClass table的css样式
  * @return
  * @throws Exception
  * */
 public StringBuffer read(String excelFileName, String tableClass) throws Exception {
  HSSFSheet sheet = null;
  StringBuffer lsb = new StringBuffer();
  try {
   HSSFWorkbook workbook = new HSSFWorkbook(new FileInputStream(excelFileName)); // 获整个Excel
   for (int sheetIndex = 0; sheetIndex < workbook.getNumberOfSheets(); sheetIndex++) {
    sheet = workbook.getSheetAt(sheetIndex);// 获所有的sheet
    if (workbook.getSheetAt(sheetIndex) != null) {
     sheet = workbook.getSheetAt(sheetIndex);// 获得不为空的这个sheet
     if (sheet != null) {
      int firstRowNum = sheet.getFirstRowNum(); // 第一行
      int lastRowNum = sheet.getLastRowNum(); // 最后一行
      // 构造Table
      lsb.append("<table class=\"" + tableClass + "\">\n");
      for (int rowNum = firstRowNum; rowNum <= lastRowNum; rowNum++) {
       if (sheet.getRow(rowNum) != null) {// 如果行不为空,
        HSSFRow row = sheet.getRow(rowNum);
        short firstCellNum = row.getFirstCellNum(); // 该行的第一个单元格
        short lastCellNum = row.getLastCellNum(); // 该行的最后一个单元格
        lsb.append("<tr>");
        for (short cellNum = firstCellNum; cellNum <= lastCellNum; cellNum++) { // 循环该行的每一个单元格
         HSSFCell cell = row.getCell(cellNum);
         if (cell != null) {
          if (cell.getCellType() == HSSFCell.CELL_TYPE_BLANK) {
           continue;
          }else {
           if(rowNum == firstRowNum){
            StringBuffer tdStyle =new StringBuffer("<th>");
            lsb.append(tdStyle);
            lsb.append(getCellValue(cell)+"</th>");
           }else{
            StringBuffer tdStyle =new StringBuffer("<td>");
            lsb.append(tdStyle);
            lsb.append(getCellValue(cell)+"</td>");
           }
          }
         }
        }
        lsb.append("</tr>\n");
       }
      }
      lsb.append("</table>\n");
     }
    }
   }
  } catch (FileNotFoundException e) {
   throw new Exception("文件 " + excelFileName + " 没有找到!");
  } catch (IOException e) {
   throw new Exception("文件 " + excelFileName + " 处理错误("
     + e.getMessage() + ")!");
  }
  return lsb;
 }
 /**
  * 读取 Excel表格原样输出
  * @param excelFileName Excel文件名
  * @return
  * @throws Exception
  */
 public StringBuffer read(String excelFileName) throws Exception {
  HSSFSheet sheet = null;
  StringBuffer lsb = new StringBuffer();
  try {
   HSSFWorkbook workbook = new HSSFWorkbook(new FileInputStream(excelFileName)); // 获整个Excel
   for (int sheetIndex = 0; sheetIndex < workbook.getNumberOfSheets(); sheetIndex++) {
    sheet = workbook.getSheetAt(sheetIndex);// 获所有的sheet
    //String sheetName = workbook.getSheetName(sheetIndex); // sheetName
    if (workbook.getSheetAt(sheetIndex) != null) {
     sheet = workbook.getSheetAt(sheetIndex);// 获得不为空的这个sheet
     if (sheet != null) {
      int firstRowNum = sheet.getFirstRowNum(); // 第一行
      int lastRowNum = sheet.getLastRowNum(); // 最后一行
      // 构造Table
      lsb.append("<table width=\"100%\" style=\"border:1px solid #000;border-width:1px 0 0 1px;margin:2px 0 2px 0;border-collapse:collapse;\">\n");
      for (int rowNum = firstRowNum; rowNum <= lastRowNum; rowNum++) {
       if (sheet.getRow(rowNum) != null) {// 如果行不为空,
        HSSFRow row = sheet.getRow(rowNum);
        short firstCellNum = row.getFirstCellNum(); // 该行的第一个单元格
        short lastCellNum = row.getLastCellNum(); // 该行的最后一个单元格
        int height = (int) (row.getHeight()/15.625); // 行的高度
        lsb.append("<tr height=\""+height+"\" style=\"border:1px solid #000;border-width:0 1px 1px 0;margin:2px 0 2px 0;\">");
        for (short cellNum = firstCellNum; cellNum <= lastCellNum; cellNum++) { // 循环该行的每一个单元格
         HSSFCell cell = row.getCell(cellNum);
         if (cell != null) {
          if (cell.getCellType() == HSSFCell.CELL_TYPE_BLANK) {
           continue;
          }else {
           StringBuffer tdStyle =new StringBuffer("<td style=\"border:1px solid #000; border-width:0 1px 1px 0;margin:2px 0 2px 0; ");
           HSSFCellStyle cellStyle = cell.getCellStyle();
           HSSFPalette palette = workbook.getCustomPalette(); //类HSSFPalette用于求颜色的国际标准形式
           HSSFColor hColor = palette.getColor(cellStyle.getFillForegroundColor());
           HSSFColor hColor2 = palette.getColor(cellStyle.getFont(workbook).getColor());
           
           String bgColor = convertToStardColor(hColor);//背景颜色
           short boldWeight = cellStyle.getFont(workbook).getBoldweight(); // 字体粗细
           short fontHeight = (short) (cellStyle.getFont(workbook).getFontHeight() / 2); // 字体大小
           String fontColor = convertToStardColor(hColor2); // 字体颜色
           if(bgColor != null && !"".equals(bgColor.trim())){
            tdStyle.append(" background-color:" + bgColor + "; ");
           }
           if(fontColor != null && !"".equals(fontColor.trim())) {
            tdStyle.append(" color:" + fontColor + "; ");
           }
           tdStyle.append(" font-weight:" + boldWeight + "; ");
           tdStyle.append(" font-size: " + fontHeight + "%;");
           lsb.append(tdStyle + "\"");
           
           int width = (int) (sheet.getColumnWidth(cellNum)/ 35.7); //
           int cellReginCol = getMergerCellRegionCol(sheet,rowNum, cellNum); // 合并的列(solspan)
           int cellReginRow = getMergerCellRegionRow(sheet, rowNum, cellNum);// 合并的行(rowspan)
           String align = convertAlignToHtml(cellStyle.getAlignment()); //
           String vAlign = convertVerticalAlignToHtml(cellStyle.getVerticalAlignment());
             
           lsb.append(" align=\"" + align + "\" valign=\""+vAlign+"\" width=\"" + width + "\" ");
           lsb.append(" colspan=\"" + cellReginCol + "\" rowspan=\""+cellReginRow+"\"");
           lsb.append(">"+getCellValue(cell)+"</td>");
          }
         }
        }
        lsb.append("</tr>\n");
       }
      }
      lsb.append("</table>\n");
     }
    }
   }
  } catch (FileNotFoundException e) {
   throw new Exception("文件 " + excelFileName + " 没有找到!");
  } catch (IOException e) {
   throw new Exception("文件 " + excelFileName + " 处理错误("
     + e.getMessage() + ")!");
  }
  return lsb;
 }

 /**
  * 取得单元格的值
  * @param cell
  * @return
  * @throws IOException
  */
 private static Object getCellValue(HSSFCell cell) throws IOException {
  Object value = "";
  if (cell.getCellType() == HSSFCell.CELL_TYPE_STRING) {
   value = cell.getRichStringCellValue().toString();
  } else if (cell.getCellType() == HSSFCell.CELL_TYPE_NUMERIC) {
   if (HSSFDateUtil.isCellDateFormatted(cell)) {
    Date date = cell.getDateCellValue();
    SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
    value = sdf.format(date);
   } else {
    double value_temp = (double) cell.getNumericCellValue();
    BigDecimal bd = new BigDecimal(value_temp);
    BigDecimal bd1 = bd.setScale(3, bd.ROUND_HALF_UP);
    value = bd1.doubleValue();
    
    /*
    DecimalFormat format = new DecimalFormat("#0.###");
    value = format.format(cell.getNumericCellValue());
    */
   }
  }
  if (cell.getCellType() == HSSFCell.CELL_TYPE_BLANK) {
   value = "";
  }
  return value;
 }
 
 /**
  * 判断单元格在不在合并单元格范围内,如果是,获取其合并的列数。
  * @param sheet 工作表
  * @param cellRow 被判断的单元格的行号
  * @param cellCol 被判断的单元格的列号
  * @return
  * @throws IOException
  */
 private static int getMergerCellRegionCol(HSSFSheet sheet, int cellRow,int cellCol) throws IOException {
  int retVal = 0;
  int sheetMergerCount = sheet.getNumMergedRegions();
  for (int i = 0; i < sheetMergerCount; i++) {
   CellRangeAddress cra = (CellRangeAddress) sheet.getMergedRegion(i);
   int firstRow = cra.getFirstRow();  // 合并单元格CELL起始行
   int firstCol = cra.getFirstColumn(); // 合并单元格CELL起始列
   int lastRow = cra.getLastRow(); // 合并单元格CELL结束行
   int lastCol = cra.getLastColumn(); // 合并单元格CELL结束列
   if (cellRow >= firstRow && cellRow <= lastRow) { // 判断该单元格是否是在合并单元格中
    if (cellCol >= firstCol && cellCol <= lastCol) {
     retVal = lastCol - firstCol+1; // 得到合并的列数
     break;
    }
   }
  }
  return retVal;
 }
 
 /**
  * 判断单元格是否是合并的单格,如果是,获取其合并的行数。
  * @param sheet 表单
  * @param cellRow 被判断的单元格的行号
  * @param cellCol 被判断的单元格的列号
  * @return
  * @throws IOException
  */
 private static int getMergerCellRegionRow(HSSFSheet sheet, int cellRow,int cellCol) throws IOException {
  int retVal = 0;
  int sheetMergerCount = sheet.getNumMergedRegions();
  for (int i = 0; i < sheetMergerCount; i++) {
   CellRangeAddress cra = (CellRangeAddress) sheet.getMergedRegion(i);
   int firstRow = cra.getFirstRow();  // 合并单元格CELL起始行
   int firstCol = cra.getFirstColumn(); // 合并单元格CELL起始列
   int lastRow = cra.getLastRow(); // 合并单元格CELL结束行
   int lastCol = cra.getLastColumn(); // 合并单元格CELL结束列
   if (cellRow >= firstRow && cellRow <= lastRow) { // 判断该单元格是否是在合并单元格中
    if (cellCol >= firstCol && cellCol <= lastCol) {
     retVal = lastRow - firstRow + 1; // 得到合并的行数
     break;
    }
   }
  }
  return retVal;
 }
 
 /**
  * 单元格背景色转换
  * @param hc
  * @return
  */
 private String convertToStardColor(HSSFColor hc) {
  StringBuffer sb = new StringBuffer("");
  if (hc != null) {
   int a = HSSFColor.AUTOMATIC.index;
   int b = hc.getIndex();
   if (a == b) {
    return null;
   }
   sb.append("#");
   for (int i = 0; i < hc.getTriplet().length; i++) {
    String str ;
    String str_tmp = Integer.toHexString(hc.getTriplet()[i]);
    if (str_tmp != null && str_tmp.length() < 2) {
     str = "0" + str_tmp;
    }else {
     str = str_tmp;
    }
    sb.append(str);
   }
  }
  return sb.toString();
 }
 
 /**
  * 单元格水平对齐
  * @param alignment
  * @return
  */
 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;
 }
 
 /**
  * 单元格垂直对齐
  * @param verticalAlignment
  * @return
  */
 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;
 }
 
 public static void main(String[] args){
  OperateExcel operateExcel = new OperateExcel();
  String excelFileName = "F:/asia/excel/anshan.xls";
  String tableCss = "info_4g_table4";
  try{
   System.out.println(operateExcel.read(excelFileName));
   System.out.println(operateExcel.read(excelFileName, tableCss));
  }catch(Exception e){
   e.printStackTrace();
  }
 }
}
 

猜你喜欢

转载自blog.csdn.net/aa1bb1cc2/article/details/34178507