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

简介: 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.Has

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;
 }
}

目录
相关文章
|
2月前
|
安全 Java 数据库连接
jdbc解析excel文件,批量插入数据至库中
jdbc解析excel文件,批量插入数据至库中
21 0
|
2月前
|
前端开发 UED
前端解析Excel文件
前端解析Excel文件
38 0
|
2月前
|
存储 Python
用python将csv转excel (.xls和.xlsx)的几种方式
用python将csv转excel (.xls和.xlsx)的几种方式
140 4
|
5月前
|
JSON JavaScript 数据格式
Node.js实现服务器端生成Excel文件(xls格式、xlsx格式文件)并弹出下载文件
Node.js实现服务器端生成Excel文件(xls格式、xlsx格式文件)并弹出下载文件
|
5月前
|
安全 算法 Java
Java之并发工具类的详细解析
3. 并发工具类 3.1 并发工具类-Hashtable Hashtable出现的原因 : 在集合类中HashMap是比较常用的集合对象,但是HashMap是线程不安全的(多线程环境下可能会存在问题)。为了保证数据的安全性我们可以使用Hashtable,但是Hashtable的效率低下。
30 0
|
2月前
|
Java
SpringBoot操作excel文件【工具类】
SpringBoot操作excel文件【工具类】
189 0
|
2月前
|
安全 Java 数据库连接
jdbc实现批量给多个表中更新数据(解析Excel表数据插入到数据库中)
jdbc实现批量给多个表中更新数据(解析Excel表数据插入到数据库中)
156 0
|
2月前
|
JSON 数据格式
人脸检测解析json的工具类face_test
人脸检测解析json的工具类face_test
15 0
|
2月前
|
存储 数据处理 数据格式
Python中导入Excel数据:全面解析与实践
Python中导入Excel数据:全面解析与实践
76 0
|
3月前
|
Java Linux 数据安全/隐私保护
Java【代码 16】将word、excel文件转换为pdf格式和将pdf文档转换为image格式工具类分享(Gitee源码)aspose转换中文乱码问题处理
【2月更文挑战第3天】Java 将word、excel文件转换为pdf格式和将pdf文档转换为image格式工具类分享(Gitee源码)aspose转换中文乱码问题处理
122 0

推荐镜像

更多