`
蹲街吃豆腐
  • 浏览: 7038 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

Poi方式解析excel

阅读更多

最近项目需要实现几个excel导入导出的功能、最开始用的jxl、不过jxl不能解析07以上的文档、感觉不是很方便、感觉apache官方的API对微软的文档支持还不错、便试着用了一下、比jxl稍微复杂了一点点、不过好在功能比较齐全、适用性比较强、

这里只用Poi解析和创建了excel文档、像word、ppt之类的后面研究一下、

依赖包:

poi-3.7-20101029.jar

poi-ooxml-3.7-20101029.jar 

poi-ooxml-schemas-3.7-20101029.jar 

poi-scratchpad-3.7-20101029.jar 

xmlbeans-2.3.0.jar 

geronimo-stax-api_1.0_spec-1.0.jar 

dom4j-1.6.1.jar

后面几个包不能缺、不然解析07的会有异常

  1. 解析excel
    /**
    	 * 解析excel文件 03/07
    	 * 
    	 * @param file
    	 * @return
    	 * @throws Exception
    	 */
    	public static List<Map<String, Object>> import2Excel(File file)
    			throws Exception {
    		// 数据头map
    		Map<String, String> headerMap = new HashMap<String, String>();
    		List<Map<String, Object>> returnList = new ArrayList<Map<String, Object>>();
    		// 工作簿
    		Workbook wb = null;
    		FileInputStream is = null;
    
    		is = new FileInputStream(file);
    		wb = WorkbookFactory.create(is);
    		// 读取行和列
    		Sheet sheet = wb.getSheetAt(0);
    		int row = sheet.getPhysicalNumberOfRows();
    		// 读取头
    		Row header = sheet.getRow(0);
    		// 列数
    		int column = header.getPhysicalNumberOfCells();
    		for (int i = 0; i < column; i++) {// 读取头
    			Cell tempCell = header.getCell(i);
    			String content = tempCell.getStringCellValue();
    			headerMap.put(String.valueOf(i), content);
    		}
    		// 读取记录
    		for (int i = 1; i < row; i++) {
    			Map<String, Object> tempMap = new HashMap<String, Object>();
    			Row tempRow = sheet.getRow(i);
    			for (int j = 0, length = tempRow.getPhysicalNumberOfCells(); j < length; j++) {
    				Cell tempCell = tempRow.getCell(j);
    				Object content = new Object();
    				switch (tempCell.getCellType()) {
    				case Cell.CELL_TYPE_FORMULA:
    					content = tempCell.getCellFormula();
    					break;
    				case Cell.CELL_TYPE_NUMERIC:
    					if (HSSFDateUtil.isCellDateFormatted(tempCell)) {
    						content = tempCell.getDateCellValue();
    					} else {
    						content = tempCell.getNumericCellValue();
    					}
    					break;
    				case Cell.CELL_TYPE_STRING:
    					content = tempCell.getStringCellValue();
    					break;
    				case Cell.CELL_TYPE_BOOLEAN:
    					content = tempCell.getBooleanCellValue();
    					break;
    				default:
    					content = "";
    				}
    				tempMap.put(headerMap.get(String.valueOf(j)), content);
    			}
    			returnList.add(tempMap);
    		}
    
    		return returnList;
    	}
     
  2. 创建excel
    /**
    	 * 创建07工作簿
    	 * 
    	 * @param title
    	 * @param dataSet
    	 * @param sheetname
    	 * @return
    	 * @throws Exception
    	 */
    	public static Workbook export2Excel07(Map<String, String> title,
    			List<Map<String, Object>> dataSet, String sheetname)
    			throws Exception {
    		// 创建工作簿
    		Workbook wb = new XSSFWorkbook();
    		Sheet sheet = wb.createSheet(sheetname);
    		// 输入头
    		Row headerRow = sheet.createRow(0);
    		int columnCount = 0;
    		Map<String, String> covertMap = new HashMap<String, String>();
    		for (Map.Entry<String, String> entry : title.entrySet()) {
    			String value = entry.getValue();
    			covertMap.put(String.valueOf(columnCount), entry.getKey());
    			headerRow.createCell(columnCount).setCellValue(value);
    			columnCount++;
    		}
    		// 输入记录
    		for (int i = 0; i < dataSet.size(); i++) {
    			Row tempRow = sheet.createRow(i + 1);
    			for (int j = 0; j < columnCount; j++) {
    				tempRow.createCell(j).setCellValue(
    						""
    								+ dataSet.get(i).get(
    										covertMap.get(String.valueOf(j))));
    			}
    		}
    		return wb;
    	}
     创建03的差不多、接口都一样,实现类不同一点、、、
    /**
    	 * 创建03工作簿
    	 * 
    	 * @param title
    	 * @param dataSet
    	 * @param sheetname
    	 * @return
    	 * @throws Exception
    	 */
    	public static HSSFWorkbook export2Excel03(Map<String, String> title,
    			List<Map<String, Object>> dataSet, String sheetname)
    			throws Exception {
    		// 创建工作簿
    		HSSFWorkbook wb = new HSSFWorkbook();
    		HSSFSheet sheet = wb.createSheet(sheetname);
    		// 输入头
    		Row headerRow = sheet.createRow(0);
    		int columnCount = 0;
    		Map<String, String> covertMap = new HashMap<String, String>();
    		for (Map.Entry<String, String> entry : title.entrySet()) {
    			String value = entry.getValue();
    			covertMap.put(String.valueOf(columnCount), entry.getKey());
    			headerRow.createCell(columnCount).setCellValue(value);
    			columnCount++;
    		}
    		// 输入记录
    		for (int i = 0; i < dataSet.size(); i++) {
    			Row tempRow = sheet.createRow(i + 1);
    			for (int j = 0; j < columnCount; j++) {
    				tempRow.createCell(j).setCellValue(
    						""
    								+ dataSet.get(i).get(
    										covertMap.get(String.valueOf(j))));
    			}
    		}
    		return wb;
    	}
     设置格式什么的就没有弄了、大概看看文档设置起来也容易、、
分享到:
评论

相关推荐

    POI 3.8解析Excel2003、Excel2007

    在本文中,我们将深入探讨如何使用POI 3.8版本解析Excel2003和Excel2007文件。 1. **POI 3.8概述** - POI 3.8是Apache POI项目的一个特定版本,它提供了对旧版(如Excel 2003,使用`.xls`格式)和较新版本(如...

    POI解析Excel简单实例

    POI解析Excel简单实例

    POI java解析EXCEL

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

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

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

    poi 解析excel文件内容demo

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

    Java Poi 解析EXCEL数据

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

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

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

    poi 解析excel实例

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

    poi解析excel文件

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

    POI技术将excel解析导入mysql.pdf

    1. Apache POI技术解析Excel文档: Apache POI是Apache软件基金会的开放源代码项目,它提供了用于读取和写入Microsoft Office格式文件的API。尤其是对于Excel文档,POI提供了两种主要的Excel文件格式支持,一种是...

    poi解析excel

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

    POI解析EXCEl分层

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

    poi-解析excel的jar包

    2. **使用Apache POI解析Excel**: - 创建工作簿对象:通过`WorkbookFactory.create()`方法,你可以根据文件路径创建一个表示Excel工作簿的对象,如`HSSFWorkbook`(BIFF8格式)或`XSSFWorkbook`(OOXML格式)。 -...

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

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

    POI3.7Excel解析

    标题“POI3.7Excel解析”提示我们将重点讨论使用Apache POI 3.7版本处理Excel文件的相关知识点。 1. **Apache POI简介** Apache POI 是Apache软件基金会的一个项目,它提供了Java API,使得开发者可以使用Java处理...

    poi解析Excel所需要的包

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

    poi3.6 解析excel程序

    在本示例中,我们将重点关注如何使用Apache POI 3.6版本解析Excel 2003(.xls)文件。Excel 2003文件使用的是HSSF(Horrible Spreadsheet Format)API,它是POI项目早期版本支持的老式Excel格式。 Apache POI 提供...

    解析Excel格式数据的poi的jar包

    使用Apache POI解析Excel数据的基本步骤如下: 1. **添加依赖**:将对应的poi.jar包引入项目类路径。如果是Maven项目,可以在pom.xml文件中添加依赖项,如下: ```xml &lt;groupId&gt;org.apache.poi &lt;artifactId&gt;...

    poi java解析excel文件实用demo

    Java使用poi的jar包解析excel,里面有个ExcelUtil工具类, 非常实用,里面有main函数可以测试,导入到eclipse里面就可以运行, 有测试excel文件,需要的jar都在里面, 导入就可以运行.

    通过poi解析Excel示例

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

Global site tag (gtag.js) - Google Analytics