`

POI解析Excel文件

 
阅读更多

 

 

  1. Demo 1
import java.io.File;
import java.io.FileInputStream;

import org.apache.poi.hssf.usermodel.HSSFCell;
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 FileAnaly {
	
	public static void main(String[] args) {
		
		try {
			
			//获取文件流
			POIFSFileSystem pois = new POIFSFileSystem(new FileInputStream(new File("D:/codeimages/账户信息.xls")));
			//新建WorkBook
			HSSFWorkbook wb = new HSSFWorkbook(pois);
			//获取Sheet(工作薄)总个数
			int sheetNumber = wb.getNumberOfSheets();
			
			for (int i = 0; i < sheetNumber; i++) {
				//获取Sheet(工作薄)
				HSSFSheet sheet = wb.getSheetAt(i);
				//开始行数
				int firstRow = sheet.getFirstRowNum();
				//结束行数
				int lastRow = sheet.getLastRowNum();
				//判断该Sheet(工作薄)是否为空
				boolean isEmpty = false;
				if(firstRow == lastRow){
					isEmpty = true;
				}
				
				if(!isEmpty){
					for (int j = firstRow; j <= lastRow; j++) {
						//获取一行
						HSSFRow row = sheet.getRow(j);
						//开始列数
						int firstCell = row.getFirstCellNum();
						//结束列数
						int lastCell = row.getLastCellNum();
						//判断该行是否为空
						if(firstCell != lastCell){
							
							for (int k = firstCell; k < lastCell; k++) {
								//获取一个单元格
								HSSFCell cell = row.getCell(k);
								Object value = null;
								//  类型说明
								//  CELL_TYPE_NUMERIC 数值型 0
								//	CELL_TYPE_STRING 字符串型 1
								//	CELL_TYPE_FORMULA 公式型 2
								//	CELL_TYPE_BLANK 空值 3
								//	CELL_TYPE_BOOLEAN 布尔型 4
								//	CELL_TYPE_ERROR 错误 5
								
								//获取单元格,值的类型
								int cellType = cell.getCellType();
								
								if(cellType == 0){
									value = cell.getNumericCellValue();
									System.out.print(value+"	");
								}else if(cellType == 1){
									value = cell.getStringCellValue();
									System.out.print(value+"	");
								}else if(cellType == 2){
									System.out.print(cell.getCellFormula());
								}else if(cellType == 4){
									value = cell.getBooleanCellValue();
									System.out.print(value+"	");
								}
								
							}
							
						}
						System.out.print("\n");
						
					}
					
				}
				
			}
			
		} catch (Exception e) {
			e.printStackTrace();
		}
		
		
	}
}

 

  2. Demo 2

 

package test.tool.excel;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.text.NumberFormat;
import java.util.ArrayList;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;

import test.tool.path.PathTool;

/*
 * 操作Excel工具类,建议首先将excel单元格设置成文本(设置单元格格式——数字——文本),
 * 否则取出的数据可能会发生格式的转变。
 * 目前仅支持xls文件,不支持xlsx。
 * 目前对于空字符串的约定:当从excel取出来的值是""时,执行往数据库插入数据时,需要加个判断,如果=="",则拼接sql可以处理成字段=''
 */
public class ExcelTool {

	/*
	 * 获取excel File
	 * return java.io.file
	 */
	public static File getExcelFile(String excel_file_dir){
	
		String excel_file = PathTool.getTestDataPath()+excel_file_dir;
		File excelFile = new File(excel_file);
		
		if(!excelFile.exists()){
			throw new RuntimeException(excel_file+" 文件不存在!");
		}
		if(!excelFile.getName().endsWith(".xls")){
			throw new RuntimeException(excel_file+" 文件类型不正确,只允许.xls结尾的文件!");
		}
		return excelFile;
	}

	/*
	 * 获取指定标签页名称的数据
	 */
	public static List<Map<String,Object>> getExcelRecords(String excel_file_dir,String sheetName){
		if(sheetName==null){
			throw new RuntimeException("标签页名称不能为空!");
		}
		return getExcelRecords(excel_file_dir, sheetName, -1);
	}
	/*
	 * 获取指定标签页索引的数据
	 */
	public static List<Map<String,Object>> getExcelRecords(String excel_file_dir,int sheetIndex){
		if(sheetIndex<0){
			throw new RuntimeException("指定标签页索引不合法,请输入非负数!");
		}
		return getExcelRecords(excel_file_dir, null, sheetIndex);
	}
	/*
	 * 获取指定excel文件、指定标签页(标签页名称、标签页索引)的内容,返回值格式:List<List<Object>>
	 * 入参excel_file格式:bpm\\test1.xls,bsp\\test2.xls
	 */
	private static List<Map<String,Object>> getExcelRecords(String excel_file_dir,String sheetName,int sheetIndex){
		
		File excelFile = getExcelFile(excel_file_dir);
		List<Map<String,Object>> recordList = new ArrayList<Map<String,Object>>();
		HSSFWorkbook workbook=null;
		
			try {
				workbook = new HSSFWorkbook(new FileInputStream(excelFile));
			} catch (FileNotFoundException e) {
				e.printStackTrace();
			} catch (IOException e) {
				e.printStackTrace();
			}
		
		
		//获取指定标签页   
		HSSFSheet sheet = null;
		if(sheetName==null){
			sheet = workbook.getSheetAt(sheetIndex);
			if(sheet==null){
				throw new RuntimeException(sheetIndex+" 标签页不存在!");
			}
		}else{		
			sheet = workbook.getSheet(sheetName);
			if(sheet==null){
				throw new RuntimeException(sheetName+" 标签页不存在!");
			}
		}
		
	
		//总行数
		int rows = sheet.getPhysicalNumberOfRows();
		if (rows < 2) {
			throw new RuntimeException(excelFile.getName()+" 内容为空,请重新编辑!");
		}

		//不为空的单元格数  ,第一行是标题列
		HSSFRow keyRow = sheet.getRow(0);
		int cellNumber = keyRow.getPhysicalNumberOfCells();
		
		//循环遍历,第一行是标题,所以从 1 开始遍历(0表示第一行,1表示第二行)
		 for (int r = 1; r < rows; r++) {
			Map<String,Object> record = new LinkedHashMap<String,Object>();//使用HashMap的话,存进去的顺序与取出来的顺序是不一致的,此处需要使用LinkedHashMap
			HSSFRow row = sheet.getRow(r);
				Object value = null;
				 for (int c = 0; c < cellNumber; c++) //共cellNumber列
				{
					HSSFCell cell = row.getCell(c);

					//如果单元格不为空
					if (cell != null) {				
						switch (cell.getCellType()) {
						case HSSFCell.CELL_TYPE_FORMULA:
							break;
						case HSSFCell.CELL_TYPE_NUMERIC:
							//对数字进行格式化,使其不自动转化为科学计数法。
							java.text.NumberFormat nf = java.text.NumberFormat.getInstance(); 
							nf.setGroupingUsed(false); 
							value = nf.format( new Double(cell.getNumericCellValue()));
							break;
						case HSSFCell.CELL_TYPE_STRING:
							value = cell.getStringCellValue();
							break;
						case HSSFCell.CELL_TYPE_BLANK:
							value = null;
							break;
						default:
							value = null;
						}
					}else{
						value=null;
					}
					record.put(keyRow.getCell(c).getStringCellValue(),value);
				}
				 recordList.add(record);
		}	
		return recordList;
	}
	/*
	 * 获取excel的sheet个数
	 */
	public static int getNumberOfSheets(String excel_file_dir){
		File excelFile = getExcelFile(excel_file_dir);
		HSSFWorkbook workbook=null;
		int numberOfSheets = 0;
		try {
			workbook = new HSSFWorkbook(new FileInputStream(excelFile));
			numberOfSheets = workbook.getNumberOfSheets();
		} catch (FileNotFoundException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}
		return numberOfSheets;
	}
	
	/*
	 * 根据sheetIndex获取sheetName
	 */
	public static String getSheetNameBySheetIndex(String excel_file_dir,int sheetIndex){
		File excelFile = getExcelFile(excel_file_dir);
		HSSFWorkbook workbook=null;
		String sheetName = null;
		try {
			workbook = new HSSFWorkbook(new FileInputStream(excelFile));
			sheetName = workbook.getSheetName(sheetIndex);
		} catch (FileNotFoundException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}
		return sheetName;
	}
	
	/*
	 * 获取指定选项卡(索引)的行数
	 */
	public static int getRowsOfSheet(String excel_file_dir,int sheetIndex){
		File excelFile = getExcelFile(excel_file_dir);
		HSSFWorkbook workbook=null;
		int rowsOfSheet = 0;
		try {
			workbook = new HSSFWorkbook(new FileInputStream(excelFile));
			rowsOfSheet = workbook.getSheetAt(sheetIndex).getPhysicalNumberOfRows();
		} catch (FileNotFoundException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}
		return rowsOfSheet;
	}
	/*
	 * 获取指定选项卡(名称)的行数
	 */
	public static int getRowsOfSheet(String excel_file_dir,String sheetName){
		File excelFile = getExcelFile(excel_file_dir);
		HSSFWorkbook workbook=null;
		int rowsOfSheet = 0;
		try {
			workbook = new HSSFWorkbook(new FileInputStream(excelFile));
			rowsOfSheet = workbook.getSheet(sheetName).getPhysicalNumberOfRows();
		} catch (FileNotFoundException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}
		return rowsOfSheet;
	}
	/*
	 * 获取指定sheet、指定row、指定colum对应的cell的value
	 * return:List[title,value],第一个元素是title,第二个元素是value
	 * row/cell都是从0开始计算
	 */
	public static List<String> getCell(String excel_file_dir,int sheetIndex,int rowIndex,int cellIndex){
		
		File excelFile = getExcelFile(excel_file_dir);
		List<String> keyValueList = new ArrayList<String>();
		HSSFWorkbook workbook=null;
		String key = null;
		String value = null;
		try {
			workbook = new HSSFWorkbook(new FileInputStream(excelFile));
			key = workbook.getSheetAt(sheetIndex).getRow(0).getCell(cellIndex).getStringCellValue();//第一行(row 0)是标题列
			HSSFCell cell = workbook.getSheetAt(sheetIndex).getRow(rowIndex).getCell(cellIndex);
			if(cell==null){
				value = null;
			}else{
				if(cell.getCellType()==HSSFCell.CELL_TYPE_NUMERIC){//如果是数字类型
					NumberFormat nf = NumberFormat.getInstance(); 
					nf.setGroupingUsed(false); 
					value = nf.format( new Double(cell.getNumericCellValue()));
				}else if(cell.getCellType()==HSSFCell.CELL_TYPE_STRING){	//如果是文本类型	
					value = cell.getStringCellValue();
				}else{//否则全部视为null
					value=null;
				}
			}
			keyValueList.add(key);
			keyValueList.add(value);
		} catch (FileNotFoundException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}
		return keyValueList;
	}
}

 

 

 

分享到:
评论

相关推荐

    poi解析excel文件

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

    poi 解析excel文件内容demo

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

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

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

    POI解析excel文件

    2. **解析Excel文件** - **创建工作簿对象**: 使用`WorkbookFactory.create()`方法,传入一个InputStream,可以打开并加载Excel文件。 - **获取工作表**: 通过调用`Workbook`对象的`getSheet()`或`getSheetAt()`...

    用poi解析Excel文件

    这篇博客文章“用poi解析Excel文件”将深入探讨如何使用Apache POI库来操作Excel数据。 首先,Apache POI提供了HSSF和XSSF两个API,分别用于处理老版本的.xls文件(BIFF8格式)和新版本的.xlsx文件(OOXML格式)。...

    poi解析excel的poi包

    以上就是使用Apache POI解析Excel文件并将数据存入Oracle数据库的基本步骤。在实际应用中,你可能需要根据具体需求进行调整,例如处理不同类型的单元格(数字、日期等)、异常处理、优化性能等。

    Java用poi读取excel文件

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

    java 中 poi解析Excel文件版本问题解决办法

    Java 中 POI 解析 Excel 文件版本问题解决办法 Java 中 POI 解析 Excel 文件版本问题解决办法是 Java 开发者经常遇到的一个问题。POI(Poor Obfuscation Implementation)是 Apache 软件基金会的一个开源项目,提供...

    poi读取大文件Excel,使用xml格式解析,速度实测50mb文件13s,可指定sheet页内容,带工具类和测试类

    在处理大型Excel文件时,传统的HSSF和XSSF模型可能会遇到性能瓶颈,因为它们将整个工作簿加载到内存中。为了解决这个问题,POI提供了SXSSF(Streaming Usermodel API)和XSSFEventUserModel API。这里的主题是利用...

    Java Poi 解析EXCEL数据

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

    Android通过POI完美解析Excel.xls xlsx成html编译前jar包

    接下来,我们将讨论如何使用POI解析Excel文件。在Android中,你可以使用以下步骤: 1. **读取Excel文件**:使用`XSSFWorkbook`类(针对.xlsx文件)或`HSSFWorkbook`类(针对.xls文件)打开Excel文件。例如: ```...

    POI解析EXCEl分层

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

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

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

    poi 解析excel实例

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

    poi解析excel

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

    poi解析Excel所需要的包

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

    poi解析jsp上传的excel文件并导入mysql(支持xls和xlsx)优化版

    POI解析Excel文件** - POI API提供了HSSF(处理.xls格式)和XSSF(处理.xlsx格式)两个接口,允许程序读取和写入Excel文件。 - 使用POI,可以逐行逐列地访问Excel工作表中的数据,将单元格的值读取出来,便于...

    通过poi解析Excel示例

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

    POI解析Excel文档

    【标题】"POI解析Excel文档"涉及到的主要技术是Apache POI库,它是一个用于读取和写入Microsoft Office格式档案的开源Java API。在Java编程环境中,使用POI库可以方便地处理Excel(.xlsx和.xls)文件,进行数据的...

Global site tag (gtag.js) - Google Analytics