ExcelParser ,Excel解析的工具类(正对解析xlsx)

本文介绍了一个用于解析Excel文件的Java类,能够读取Excel表格并提取其中的数据和列名。该类支持不同类型的单元格格式,并提供了获取列名、读取内容的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

package cn.com.css.common.util;

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.math.BigDecimal;
import java.util.HashMap;
import java.util.Map;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.xssf.usermodel.XSSFCell;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

public class ExcelParser {
 private XSSFWorkbook xssfWorkbook;
 private XSSFSheet xssfSheet;
 private XSSFRow xssfRow;
 private int columnNumbers;
 private int totalRows;

 /**
  * @param args
  * @throws Exception
  */
 private String getCellFormatValue(XSSFCell cell) {
  String cellvalue = "";
  if (cell != null) {
   // 判断当前Cell的Type
   switch (cell.getCellType()) {
   // 如果当前Cell的Type为NUMERIC
   case XSSFCell.CELL_TYPE_NUMERIC: {
    BigDecimal big = new BigDecimal(cell.getNumericCellValue());
    cellvalue = big.toString();
    break;
   }
   case XSSFCell.CELL_TYPE_FORMULA: {
    // 判断当前的cell是否为Date
    /*
     * if (XSSFDateUtil.isCellDateFormatted(cell)) { //
     * 如果是Date类型则,转化为Data格式
     *
     * //方法1:这样子的data格式是带时分秒的:2011-10-12 0:00:00 //cellvalue =
     * cell.getDateCellValue().toLocaleString();
     *
     * //方法2:这样子的data格式是不带带时分秒的:2011-10-12 Date date =
     * cell.getDateCellValue(); SimpleDateFormat sdf = new
     * SimpleDateFormat("yyyy-MM-dd"); cellvalue = sdf.format(date);
     *
     * } // 如果是纯数字 else { // 取得当前Cell的数值 cellvalue =
     * String.valueOf(cell.getNumericCellValue()); }
     */
    BigDecimal bigula = new BigDecimal(cell
      .getCachedFormulaResultType());
    cellvalue = bigula.toString();
    break;
   }
    // 如果当前Cell的Type为STRIN
   case HSSFCell.CELL_TYPE_STRING:
    // 取得当前的Cell字符串
    cellvalue = cell.getRichStringCellValue().getString();
    break;
   // 默认的Cell值
   default:
    cellvalue = " ";
   }
  } else {
   cellvalue = "";
  }
  return cellvalue;

 }

 /**
  * \brief 通过这个方法获得Excel中的列名和一些excel的初始化信息,比如行数和列数
  *
  * @param is
  * @return
  * @attention
  * @author 涂作权
  * @date 2014-5-27
  * @note begin modify by null
  */
 public String[] getTitle(InputStream is) {
  try {
   xssfWorkbook = new XSSFWorkbook(is);
  } catch (IOException e) {
   e.printStackTrace();
  }
  xssfSheet = xssfWorkbook.getSheetAt(0);
  System.out.println("xssfSheet.getSheetName() = " + xssfSheet.getSheetName());

  // 获得行数
  totalRows = xssfSheet.getLastRowNum();
  System.out.println("totalRows = " + totalRows);
  xssfRow = xssfSheet.getRow(0);// first line:title
  // 获得列数
  columnNumbers = xssfRow.getPhysicalNumberOfCells();
  System.out.println("columnNumbers = " + columnNumbers);

  // 列名的集合
  String[] title = new String[columnNumbers];
  for (int i = 0; i < columnNumbers; i++) {
   title[i] = getCellFormatValue(xssfRow.getCell(i));
  }

  // 返回的是列名的数组
  return title;
 }

 public Map<Integer, String> readExcelContent(InputStream is) {
  getTitle(is);
  Map<Integer, String> content = new HashMap<Integer, String>();
  String str = "";
  // 正文内容应该从第二行开始,第一行为表头的标题
  for (int i = 1; i <= totalRows; i++) {
   xssfRow = xssfSheet.getRow(i);
   int j = 0;

   while (j <= columnNumbers) {
    String cell = getCellFormatValue(xssfRow.getCell(j)).trim();
    if (cell == "") {
     j++;
     continue;// cell="null";
    }
    str += cell + "\t";
    j++;
   }
   str.trim();
   content.put(i, str);
   str = "";
  }
  return content;
 }

 public XSSFWorkbook getXssfWorkbook() {
  return xssfWorkbook;
 }

 public void setXssfWorkbook(XSSFWorkbook xssfWorkbook) {
  this.xssfWorkbook = xssfWorkbook;
 }

 public XSSFSheet getXssfSheet() {
  return xssfSheet;
 }

 public void setXssfSheet(XSSFSheet xssfSheet) {
  this.xssfSheet = xssfSheet;
 }

 public XSSFRow getXssfRow() {
  return xssfRow;
 }

 public void setXssfRow(XSSFRow xssfRow) {
  this.xssfRow = xssfRow;
 }

 public int getColumnNumbers() {
  return columnNumbers;
 }

 public void setColumnNumbers(int columnNumbers) {
  this.columnNumbers = columnNumbers;
 }

 public int getTotalRows() {
  return totalRows;
 }

 public void setTotalRows(int totalRows) {
  this.totalRows = totalRows;
 }

 public static void main(String[] args) throws Exception {
  // 构造 XSSFWorkbook 对象,strPath 传入文件路径
  ExcelParser ep = new ExcelParser();
  InputStream is = new FileInputStream(new File("D:\\产品管理模板.xlsx"));
  //String[] titles = ep.getTitle(is);
  Map<Integer, String> map = ep.readExcelContent(is);
  
  for (int i = 1; i <= map.size(); i++) {
   String row = map.get(i);
   String rowArr[] = row.split(" ");
   // 如果每行里面有大于3列信息
   String cell0 = rowArr[0]; // 产品名
   String cell1 = rowArr[1]; // 国家编码
   System.out.println(cell0 + "\t" + cell1);
   //System.out.println(map.size());
  }
  
  is.close();
      is = null;
 }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

涂作权的博客

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值