`
daichangfu
  • 浏览: 264215 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

使用Java POI 解析EXCLE

    博客分类:
  • java
阅读更多
package com.ceshi;

import java.io.FileInputStream;
import java.util.ArrayList;
import java.util.List;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFDateUtil;
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.poifs.filesystem.POIFSFileSystem;


public class DomExcel {

	/**
	 * 解析EXCLE
	 * @param is
	 * @return
	 */
	public static List<String[]> parseExcel(FileInputStream is){
		
		List<String[]> list = null ;
		
		try {
			POIFSFileSystem fs = new POIFSFileSystem(is);
			// 创建工作簿
			HSSFWorkbook workBook = new HSSFWorkbook(fs);
			
			//储存Excle的数据
			list = new ArrayList<String[]>();
			
			// 获得Excel中工作表个数
			//System.out.println("工作表个数 :" + workBook.getNumberOfSheets());
			for (int i = 0; i < workBook.getNumberOfSheets(); i++) {
				
				//System.out.println("第" + i + "个工作表名称:" + workBook.getSheetName(i));
				// 创建工作表
				HSSFSheet sheet = workBook.getSheetAt(i);
				int rows = sheet.getPhysicalNumberOfRows();				 // 获得行数
				if (rows > 0) {
					sheet.getMargin(HSSFSheet.TopMargin);
					for (int j = 0; j < rows; j++) { 					// 行循环
						HSSFRow row = sheet.getRow(j);
						if (row != null) {
							int cells = row.getLastCellNum();			// 获得列数
							
							String[] fieldValue = new String[cells];
							
							for (short k = 0; k < cells; k++) { 		// 列循环
								HSSFCell cell = row.getCell(k);

								String value = "";
								
								if (cell != null) {
									switch (cell.getCellType()) {
									
										case HSSFCell.CELL_TYPE_NUMERIC: // 数值型
											if (HSSFDateUtil.isCellDateFormatted(cell)) {
												// 如果是date类型则,获取该cell的date值
												value = HSSFDateUtil.getJavaDate(cell.getNumericCellValue()).toString();
											} else {
												// 纯数字
												value = String.valueOf(cell.getNumericCellValue());
											}
											break;
											
										//此行表示单元格的内容为string类型 
										case HSSFCell.CELL_TYPE_STRING: 
											// 字符串型
											value = cell.getStringCellValue();
											break;
											
										case HSSFCell.CELL_TYPE_FORMULA:// 公式型
											// 读公式计算值
											value = String.valueOf(cell.getNumericCellValue());
											
											if (value.equals("NaN")) {
												// 如果获取的数据值为非法值,则转换为获取字符串
												value = cell.getStringCellValue();
											}
											break;
											
										case HSSFCell.CELL_TYPE_BOOLEAN:// 布尔
											value = ""+ cell.getBooleanCellValue();
											break;
											
										//此行表示该单元格值为空 
										case HSSFCell.CELL_TYPE_BLANK: // 空值
											value = "";
											break;
										case HSSFCell.CELL_TYPE_ERROR: // 故障
											value = "";
											break;
										default:
											value = cell.getStringCellValue();
									}
								}
								fieldValue[k] = value;
							}
							list.add(fieldValue);
						}
					}
				}
			}
		} catch (Exception ex) {
			ex.printStackTrace();
		}
		
		return list;
	}
	
}
分享到:
评论

相关推荐

    Java Poi 解析EXCEL数据

    以上就是使用Java Poi解析Excel数据的基本流程。在实际应用中,你可能还需要处理其他复杂场景,比如样式、公式、超链接等。Poi库提供了丰富的API来处理这些问题,使得与Excel文件的交互变得简单且灵活。在提供的"poi...

    使用POI解析excel文件并写入数据库

    使用poi解析excel文件,并将数据写入到数据库 项目说明 这个项目实现的功能是读取excel文件中的数据,解析并写入数据库。 读取的excel文件位于项目目录下的 excel\0805.xlsx 使用IntelliJ IDEA开发此项目 使用MYSQL...

    利用POI解析excel并存入数据库demo

    在这个"利用POI解析excel并存入数据库demo"中,我们将关注如何使用 POI 库来读取 Excel 文件,并将数据有效地存入 MySQL 数据库。 首先,要开始使用 POI,你需要在你的项目中引入相应的依赖。如果你使用的是 Maven...

    poi解析excel文件

    标题提到的"poi解析excel文件"是利用Apache POI 3.8版本进行Excel数据的读取和解析。 在Apache POI 3.8中,主要涉及以下核心概念: 1. **HSSF(Horrible Spreadsheet Format)**:这是Apache POI中处理旧版Excel...

    Java 使用poi导入excel 并使用xml做数据验证

    Apache POI是一个流行的库,它允许开发者使用Java来读取、写入和修改Microsoft Office格式的文件,包括Excel(.xlsx, .xls)。在本项目中,我们结合了POI库和XML技术来实现Excel数据的验证与导入数据库。 首先,...

    poi 解析excel文件内容demo

    在这个"poi 解析excel文件内容demo"中,我们主要关注如何使用Apache POI库来读取和解析Excel文件,无论它们是2003版的.XLS还是2007以后的.XLSX格式。 首先,Apache POI提供了两种主要的接口来处理Excel文件:HSSF...

    java利用POI生成与解析EXCEL所需JAR

    以上就是使用Java POI库生成和解析Excel文件的基本操作。在实际应用中,你可以根据需求进行更复杂的操作,如处理公式、图表、数据验证等。记得在操作完成后始终关闭工作簿和输入/输出流,以释放资源。此外,对于大型...

    JAVA POI Excel转Html

    JAVA POI Excel转Html,代码和所需的jar都在压缩包,项目在线预览需求,实现后分享下

    poi解析excel

    【标题】"poi解析excel"涉及的是Java编程中使用Apache POI库来处理Microsoft Excel文件的知识。Apache POI是开源项目,提供了API用于读写Microsoft Office格式的文件,特别是Excel。在Java应用中,POI使得开发者能够...

    java poi处理excel数据

    本压缩包包含了一些关键资源,帮助你理解和使用Java POI处理Excel数据。 首先,`问题.docx`可能是你在使用POI过程中遇到的问题汇总,它可能包含了错误信息、解决步骤或常见问题的解决方案。通过阅读这份文档,你...

    通过poi解析Excel示例

    本示例将深入讲解如何使用Apache POI来解析Excel文件。 Apache POI是Apache软件基金会的一个开源项目,它的主要功能是处理微软的Office Open XML (OOXML) 和早期的二进制文件格式,例如Excel的.BIFF8格式。在Java中...

    java通过poi解析Excel示例

    本示例将详细讲解如何使用Java和POI库来解析Excel文档。 首先,我们需要引入Apache POI的相关依赖。如果你使用的是Maven项目,可以在pom.xml文件中添加以下依赖: ```xml &lt;groupId&gt;org.apache.poi &lt;artifactId&gt;...

    Java用poi读取excel文件

    Java 使用 POI 读取 Excel 文件 Java 是一种广泛使用的编程语言,而 Excel 是一种常用的电子表格软件。有时候,我们需要在 Java 程序中读取 Excel 文件的内容,例如将 Excel 表格中的数据导入到数据库中或者进行...

    POI解析EXCEl分层

    标题“POI解析EXCEL分层”涉及到的主要知识点是Apache POI库在处理Microsoft Excel文件时的层次化数据解析。Apache POI是一个流行的开源Java API,它允许开发者读取、写入和修改Microsoft Office格式的文件,其中...

    poi 解析excel实例

    在描述中提到的“ poi解析excel的工具类”,通常包含了一些常用的方法,例如打开文件、读取单元格数据、处理合并单元格等。以下是一些可能包含在该工具类中的关键方法: 1. **打开文件**:使用`WorkbookFactory`类...

    apache poi解析Excel时报错,我将Excel打开后保存,就不会报错,用jar完美解决

    apache poi解析Excel时报错,我将Excel打开后保存,就不会报错,我将重写的类从新打包这样问题虽然网上有解决方案,但是需要自己打包重写对应类,我已将这些步骤做好了。

    poi解析Excel所需要的包

    在Java环境中,使用Apache POI库解析Excel文件时,确实需要引入一系列的依赖包来确保所有必要的功能得以正常运行。这些包包含了对Excel文件格式的理解和支持,允许开发者读取、写入和修改Excel数据。 1. **Apache ...

    POI java解析EXCEL

    【标题】:POI Java解析EXCEL 在Java开发中,处理Excel文件是常见的需求,Apache POI项目提供了一个强大的工具库,使得开发者能够轻松地读取、写入以及操作Microsoft Office格式的文件,尤其是Excel(.xlsx和.xls)...

    POI解析Excel文档

    总的来说,"POI解析Excel文档"的主题涵盖了Java编程、Maven项目管理和Apache POI库的使用,这些都是Java开发人员在处理Excel数据时必备的技能。通过这个主题,我们可以深入学习如何在Java环境中高效地读写Excel文件...

Global site tag (gtag.js) - Google Analytics