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

本文涉及的产品
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
简介: 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;
 }
}

目录
相关文章
|
25天前
|
人工智能 自然语言处理 Java
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
FastExcel 是一款基于 Java 的高性能 Excel 处理工具,专注于优化大规模数据处理,提供简洁易用的 API 和流式操作能力,支持从 EasyExcel 无缝迁移。
122 9
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
|
3月前
|
数据处理 Python
Python实用记录(十):获取excel数据并通过列表的形式保存为txt文档、xlsx文档、csv文档
这篇文章介绍了如何使用Python读取Excel文件中的数据,处理后将其保存为txt、xlsx和csv格式的文件。
237 3
Python实用记录(十):获取excel数据并通过列表的形式保存为txt文档、xlsx文档、csv文档
|
3月前
|
数据处理 Python
Python 高级技巧:深入解析读取 Excel 文件的多种方法
在数据分析中,从 Excel 文件读取数据是常见需求。本文介绍了使用 Python 的三个库:`pandas`、`openpyxl` 和 `xlrd` 来高效处理 Excel 文件的方法。`pandas` 提供了简洁的接口,而 `openpyxl` 和 `xlrd` 则针对不同版本的 Excel 文件格式提供了详细的数据读取和处理功能。此外,还介绍了如何处理复杂格式(如合并单元格)和进行性能优化(如分块读取)。通过这些技巧,可以轻松应对各种 Excel 数据处理任务。
287 16
|
3月前
|
前端开发 JavaScript
💥【exceljs】纯前端如何实现Excel导出下载和上传解析?
本文介绍了用于处理Excel文件的库——ExcelJS,相较于SheetJS,ExcelJS支持更高级的样式自定义且易于使用。表格对比显示,ExcelJS在样式设置、内存效率及流式操作方面更具优势。主要适用于Node.js环境,也支持浏览器端使用。文中详细展示了如何利用ExcelJS实现前端的Excel导出下载和上传解析功能,并提供了示例代码。此外,还提供了在线调试的仓库链接和运行命令,方便读者实践。
578 5
|
3月前
|
前端开发 JavaScript API
前端基于XLSX实现数据导出到Excel表格,以及提示“文件已经被损坏,无法打开”的解决方法
前端基于XLSX实现数据导出到Excel表格,以及提示“文件已经被损坏,无法打开”的解决方法
297 0
|
3月前
|
前端开发 JavaScript Java
导出excel的两个方式:前端vue+XLSX 导出excel,vue+后端POI 导出excel,并进行分析、比较
这篇文章介绍了使用前端Vue框架结合XLSX库和后端结合Apache POI库导出Excel文件的两种方法,并对比分析了它们的优缺点。
1390 0
|
5月前
|
前端开发 JavaScript
使用Vue+xlsx+xlsx-style实现导出自定义样式的Excel文件
本文介绍了在Vue项目中使用`xlsx`和`xlsx-style`(或`xlsx-style-vite`)库实现导出具有自定义样式的Excel文件的方法,并提供了详细的示例代码和操作效果截图。
1158 2
使用Vue+xlsx+xlsx-style实现导出自定义样式的Excel文件
|
5月前
|
前端开发 PHP
ThinkPHP6之Excel解析
ThinkPHP6之Excel解析
67 0
|
6月前
|
存储 对象存储 Python
`openpyxl`是一个用于读写Excel 2010 xlsx/xlsm/xltx/xltm文件的Python库。它不需要Microsoft Excel,也不需要.NET或COM组件。
`openpyxl`是一个用于读写Excel 2010 xlsx/xlsm/xltx/xltm文件的Python库。它不需要Microsoft Excel,也不需要.NET或COM组件。

热门文章

最新文章

推荐镜像

更多