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;

 }

}

ExcelParser ,Excel解析的工具类(正对解析xlsx)的更多相关文章

  1. Java解析Excel工具类(兼容xls和xlsx)

    依赖jar <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml&l ...

  2. Excel解析easyexcel工具类

    Excel解析easyexcel工具类 easyexcel解决POI解析Excel出现OOM <!-- https://mvnrepository.com/artifact/com.alibab ...

  3. 一个基于POI的通用excel导入导出工具类的简单实现及使用方法

    前言: 最近PM来了一个需求,简单来说就是在录入数据时一条一条插入到系统显得非常麻烦,让我实现一个直接通过excel导入的方法一次性录入所有数据.网上关于excel导入导出的例子很多,但大多相互借鉴. ...

  4. Workbook导出excel封装的工具类

    在实际中导出excel非常常见,于是自己封装了一个导出数据到excel的工具类,先附上代码,最后会写出实例和解释.支持03和07两个版本的 excel. HSSF导出的是xls的excel,XSSF导 ...

  5. Java基础学习总结(49)——Excel导入导出工具类

    在项目的pom文件中引入 <dependency> <groupId>net.sourceforge.jexcelapi</groupId> <artifac ...

  6. flink---实时项目--day02-----1. 解析参数工具类 2. Flink工具类封装 3. 日志采集架构图 4. 测流输出 5. 将kafka中数据写入HDFS 6 KafkaProducer的使用 7 练习

    1. 解析参数工具类(ParameterTool) 该类提供了从不同数据源读取和解析程序参数的简单实用方法,其解析args时,只能支持单只参数. 用来解析main方法传入参数的工具类 public c ...

  7. Excel导入工具类兼容xls和xlsx

    package com.bj58.finance.platform.operation.provider.util; import org.apache.log4j.Logger; import or ...

  8. 【原创】POI操作Excel导入导出工具类ExcelUtil

    关于本类线程安全性的解释: 多数工具方法不涉及共享变量问题,至于添加合并单元格方法addMergeArea,使用ThreadLocal变量存储合并数据,ThreadLocal内部借用Thread.Th ...

  9. android 解析XML 工具类

    /** * Created by John on 2016/3/29. */ public class XmlParser { private static final String ns = nul ...

  10. 导入导出Excel的Java工具类ExcelUtil

    在编写ExcelUtil之前,在网上查了一些资料.java中用来处理Excel的第三方开源项目主要就是POI和JXL.poi功能强大,但是比较耗资源,对于大数据量的导入导出性能不是太好:jxl功能简单 ...

随机推荐

  1. FreeCodeCamp:Confirm the Ending

    要求: 检查一个字符串(str)是否以指定的字符串(target)结尾. 如果是,返回true;如果不是,返回false. 结果: confirmEnding("Bastian", ...

  2. django template出错

    解决方法一: 先导入settings >>> from django.conf import settings >>> settings.configure() & ...

  3. (C)单链表

    老师版 #include <stdio.h> #include <stdlib.h> // 定于Node数据类型 struct Node { int data; // 数据域 ...

  4. 文字适应DIV

    今天突然碰到了一个奇怪的问题  那就是对于纯数字和英文字母  文字多了会超出div  且即使是设置了height:auto overflow-y:auto 也不管用 只是在x轴上出现滚动条   不论用 ...

  5. Qt探秘——谈ui文件的用法

    转载自:点击打开链接http://blog.csdn.net/luo_isaiah/article/details/5794973 相信用过Qt Designer的朋友,对Qt Project中的.u ...

  6. 解题报告 HDU1789 Doing Homework again

    Doing Homework again Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64 ...

  7. poj 2250 Compromise(区间dp)

    题目链接:http://poj.org/problem?id=2250 思路分析:最长公共子序列问题的变形,只是把字符变成了字符串,按照最长公共子序列的思路即可以求解. 代码如下: #include ...

  8. hdoj Pipe&&南阳oj管道问题&&poj1039(计算几何问题...枚举)

    Pipe Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  9. Pick-up sticks(判断两直线相交)

    Pick-up sticks Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 11335   Accepted: 4250 D ...

  10. 正确的lnamp支持SSI的方法!即支持SHTML和include调用!

    正确的lnamp支持SSI的方法!即支持SHTML和include调用! 个地方:一个是apache和nginx里的conf文件 第一步:修改apache里的httpd.conf文件 查找:AddTy ...