`

java poi 读取Excel

    博客分类:
  • java
阅读更多
java 用poi读取excel并区分2003和2007

2003 需要的jar:poi-x.jar
2007 需要的jar:poi-ooxml-x.jar poi-ooxml-schemas-x.jar,dom4j.jar,xmlbeans-2.6.0.jar

如果项目用了maven的话 pom配置中加入以下就可以了:
<properties>
    <poi-version>3.9</poi-version>
</properties>
<dependencies>
<dependency>
  <groupId>org.apache.poi</groupId>
  <artifactId>poi</artifactId>
  <version>${poi-version}</version>
</dependency>
<dependency>
  <groupId>org.apache.poi</groupId>
  <artifactId>poi-ooxml</artifactId>
  <version>${poi-version}</version>
</dependency>
<dependency>
  <groupId>org.apache.poi</groupId>
  <artifactId>poi-ooxml-schemas</artifactId>
  <version>${poi-version}</version>
</dependency>
<dependency>
  <groupId>org.apache.xmlbeans</groupId>
  <artifactId>xmlbeans</artifactId>
  <version>2.6.0</version>
</dependency>
<dependency>
  <groupId>dom4j</groupId>
  <artifactId>dom4j-core</artifactId>
  <version>1.4-dev-8</version>
</dependency>
</dependencies>  


package com.jynine.utils;

import java.io.File;
import java.io.FileInputStream;
import java.text.DecimalFormat;
import java.text.SimpleDateFormat;
import java.util.Iterator;
import java.util.LinkedList;
import java.util.List;

import org.apache.poi.hssf.usermodel.HSSFDateUtil;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.CellStyle;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

/**
 * 
 * @author jynine
 * 
 */
public class ExcelUtil {
	private static SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");// 字符
	private static DecimalFormat df = new DecimalFormat("0");// 格式化 number String
	private static DecimalFormat nf = new DecimalFormat("0.00");// 格式化数字

	public static Workbook getWorkbook(File file) throws Exception {
		String fileName = file.getName();
		String extension = fileName.lastIndexOf(".") == -1 ? "" : fileName
				.substring(fileName.lastIndexOf(".") + 1);
		FileInputStream fis = new FileInputStream(file);
		// 根据不同的文件名返回不同类型的WorkBook
		if (extension.equals("xls")) {
			return new HSSFWorkbook(fis);
		} else if (extension.equals("xlsx")) {
			return new XSSFWorkbook(fis);
		} else {
			throw new Exception("不支持该格式的文件!");
		}
	}
	/**
	 * 读取excel 文件
	 * @param file
	 * @param startSheet
	 * @param startRow
	 * @return
	 */
	public static List<List<Object>> readExcel(File file,int startSheet,int startRow) {
		List<List<Object>> list = new LinkedList<List<Object>>();
		Workbook wb = null;
		try {
			wb = getWorkbook(file);
			Sheet sheet = wb.getSheetAt(startSheet);
			Object value = null;
			Row row = null;
			Cell cell = null;
			CellStyle cs = null;
			String csStr = null;
			Double numval = null;
			Iterator<Row> rows = sheet.rowIterator();
			while (rows.hasNext()) {
				row = (Row) rows.next();
				if(row.getRowNum() >= startRow){
					List<Object> cellList = new LinkedList<Object>();;
					Iterator<Cell> cells = row.cellIterator();
					while (cells.hasNext()) {
						cell = (Cell) cells.next();
						switch (cell.getCellType()) {
						case Cell.CELL_TYPE_NUMERIC:
							cs = cell.getCellStyle();
							csStr = cs.getDataFormatString();
							numval = cell.getNumericCellValue();
							if ("@".equals(csStr)) {
								value = df.format(numval);
							} else if ("General".equals(csStr)) {
								value = nf.format(numval);
							} else {
								value = sdf.format(HSSFDateUtil.getJavaDate(numval));
							}
							break;
						case Cell.CELL_TYPE_STRING:
							value = cell.getStringCellValue();
							break;
						case Cell.CELL_TYPE_FORMULA:
							if (!cell.getStringCellValue().equals("")) {
		                        value = cell.getStringCellValue();
		                     } else {
		                        value = cell.getNumericCellValue() + "";
		                     }
							break;
						case Cell.CELL_TYPE_BLANK:
							value = "";
							break;
						case Cell.CELL_TYPE_BOOLEAN:
							value = cell.getBooleanCellValue();
							break;
						default:
							value = cell.toString();
						}
						cellList.add(value);
					}
					list.add(cellList);
				}
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
		return list;
	}
	public static void main(String[] args) {
		File file = new File("D:\\test.xlsx");
		List<List<Object>> list = readExcel(file, 0, 0);
		for (int i = 0; i < list.size(); i++) {
			List<Object> objects = list.get(i);
			for (int j = 0; j < objects.size(); j++) {
				System.out.print(objects.get(j)+"=====");
			}
			System.out.println();
		}
	}
}


分享到:
评论

相关推荐

    java POI读取excel文件数据

    在这个场景中,我们将详细探讨如何使用Java POI读取Excel文件中的数据,包括获取总行数、列数、单元格内容、合并单元格、行高、列宽以及图片等信息。 首先,确保在项目中已经引入了Apache POI的依赖库。如果你使用...

    java poi 读取excel 2007

    以上就是使用Java POI读取Excel 2007文件并将内容存储到List的基本过程。这个过程可以根据实际需求进行调整,比如处理表头、忽略空行、处理特殊格式的单元格等。在处理大数据量时,还需要考虑性能优化,例如使用迭代...

    Java POI读取excel中数值精度损失问题解决

    Java POI 读取 Excel 中数值精度损失问题解决 Java POI 读取 Excel 中数值精度损失问题解决是指在使用 Java POI 读取 Excel 文件时,遇到数值精度损失的问题。这种问题的出现是因为 Excel 中的数值单元格在读取时,...

    java POI读取Excel文件基本用法Demo

    在本示例"Java POI读取Excel文件基本用法Demo"中,我们将深入探讨如何使用Java POI库来读取Excel文件。 首先,我们需要在项目中引入Apache POI的依赖。对于Maven项目,可以在pom.xml文件中添加以下依赖: ```xml ...

    java poi 读取excel表格

    接着,我们来看看如何使用Java POI读取Excel文件。以下是一个基本示例,展示如何打开一个Excel文件并读取其内容: ```java import org.apache.poi.ss.usermodel.*; import org.apache.poi.xssf.usermodel....

    java 读取excel表格数据 poi

    java读取excel 表格数据。 public static void main(String[] args) { String[][] content=POIExcelUtils.read("E:\\1.xlsx"); for(int i=0;i;i++) { if(content[i]!=null){ for(int j=0;j[i].length;j...

    java poi读取excel xls xlsx相关jar包集合

    java poi读取excel xls xlsx相关jar包集合,包含: dom4j-1.6.1.jar jsr173_1.0_api.jar poi-3.7-20101029.jar poi-ooxml-3.7-20101029.jar poi-ooxml-schemas-3.7-20101029.jar poi-scratchpad-3.7-20101029.jar ...

    java poi读取Excel需要导入的所有包

    Java POI 是一个开源库,...因此,为了确保Java POI能够顺利读取Excel文件,开发者必须确保项目配置中包含了上述所有必要的库文件。同时,根据项目需求,可能还需要更新到最新版本的POI库,以获得更好的性能和兼容性。

    java读写Excel,POI.JAR,Word内容读取

    java读写Excel,POI.JAR,Word内容读取

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

    这个项目实现的功能是读取excel文件中的数据,解析并写入数据库。 读取的excel文件位于项目目录下的 excel\0805.xlsx 使用IntelliJ IDEA开发此项目 使用MYSQL查看数据库 在MYSQL中运行项目db目录下的sql文件,创建...

    JAVA_poi读取Excel.pdf

    JAVA POI 读取 Excel JAVA POI 是 Apache 的一个子项目,提供了一...本文总结了 JAVA POI 读取 Excel 的知识点,包括 POI 简介、Excel 文件的组织形式、POI 的主要对象、使用 POI 读取 Excel 和使用 POI 写入 Excel。

    java poi处理excel数据

    Java POI是Apache软件基金会下的一个开源项目,主要用于读写Microsoft Office格式的文件,特别是Excel。在Java开发中,当你需要处理Excel数据时,POI库是一个强大的工具。本压缩包包含了一些关键资源,帮助你理解和...

    利用POI读取excel写入到word

    要实现"利用POI读取excel写入到word",我们需要以下步骤: 1. **准备环境**:首先,确保你的项目已经引入了Apache POI的依赖。在给定的压缩包中,"poi - 副本"可能是包含POI库的JAR文件,你需要将其添加到你的项目...

    Java使用apache POI读取Excel2007以上代码以及所需jar包

    本文将详细介绍如何使用Apache POI库来读取Excel 2007及以上版本(即XLSX格式)的文件,并提供所需的jar包信息。 首先,要使用Apache POI读取XLSX文件,你需要确保引入了正确的依赖。Apache POI项目提供了多个组件...

    java poi导出图片到excel示例代码

    在示例代码中,使用了Java POI读取Excel文件,并将其写入到数据库中。首先,需要创建一个Workbook对象,然后使用Workbook对象的getSheet方法获取Excel文件的Sheet对象,最后使用Sheet对象的getRow方法读取Excel文件...

    java poi读取excel表格数据专用jar包 包括(dom4j和xmlbeans包)

    5. **读取Excel数据**:使用POI读取Excel数据的基本步骤包括: - 加载工作簿:创建HSSFWorkbook对象(.xls)或XSSFWorkbook对象(.xlsx)。 - 访问工作表:通过工作簿对象获取Sheet对象,代表Excel中的工作表。 -...

    java_poi实现excel导入导出

    Java POI 实现 Excel 导入导出 Java POI 是一个流行的 Java 库,用于处理 Microsoft Office 文件格式,包括 ...在本文中,我们已经详细介绍了如何使用 Java POI 实现 Excel 导入导出功能,包括读取和写入 Excel 文件。

    POI读取Excel合并单元格并储存

    本文将深入探讨如何使用Java的Apache POI库来读取Excel文件,并处理其中合并单元格的数据,同时将这些数据存储到实体类中以供后续使用。 Apache POI是一个强大的库,允许程序员使用Java来创建、修改和显示Microsoft...

    java+poi读取excel数据 源码

    本源码包提供了一个通用的Java POI读取Excel数据的实现,特别适用于那些需要在服务器端或无桌面环境处理Excel数据的应用。 在描述中提到,源码已经包含了poi.jar包,这是POI项目的主要依赖库,包含了处理Excel文件...

    POI读取excel的内容.zip

    本教程将详细讲解如何使用Apache POI库来读取Excel文件的内容。 首先,为了在Java项目中使用Apache POI,我们需要通过Maven进行依赖管理。在`pom.xml`文件中添加以下依赖: ```xml &lt;groupId&gt;org.apache.poi ...

Global site tag (gtag.js) - Google Analytics