最近项目需要实现几个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的会有异常
- 解析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; }
- 创建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文件。 1. **POI 3.8概述** - POI 3.8是Apache POI项目的一个特定版本,它提供了对旧版(如Excel 2003,使用`.xls`格式)和较新版本(如...
POI解析Excel简单实例
【标题】:POI Java解析EXCEL 在Java开发中,处理Excel文件是常见的需求,Apache POI项目提供了一个强大的工具库,使得开发者能够轻松地读取、写入以及操作Microsoft Office格式的文件,尤其是Excel(.xlsx和.xls)...
接下来,我们将讨论如何使用POI解析Excel文件。在Android中,你可以使用以下步骤: 1. **读取Excel文件**:使用`XSSFWorkbook`类(针对.xlsx文件)或`HSSFWorkbook`类(针对.xls文件)打开Excel文件。例如: ```...
在这个"poi 解析excel文件内容demo"中,我们主要关注如何使用Apache POI库来读取和解析Excel文件,无论它们是2003版的.XLS还是2007以后的.XLSX格式。 首先,Apache POI提供了两种主要的接口来处理Excel文件:HSSF...
以上就是使用Java Poi解析Excel数据的基本流程。在实际应用中,你可能还需要处理其他复杂场景,比如样式、公式、超链接等。Poi库提供了丰富的API来处理这些问题,使得与Excel文件的交互变得简单且灵活。在提供的"poi...
使用poi解析excel文件,并将数据写入到数据库 项目说明 这个项目实现的功能是读取excel文件中的数据,解析并写入数据库。 读取的excel文件位于项目目录下的 excel\0805.xlsx 使用IntelliJ IDEA开发此项目 使用MYSQL...
在描述中提到的“ poi解析excel的工具类”,通常包含了一些常用的方法,例如打开文件、读取单元格数据、处理合并单元格等。以下是一些可能包含在该工具类中的关键方法: 1. **打开文件**:使用`WorkbookFactory`类...
标题提到的"poi解析excel文件"是利用Apache POI 3.8版本进行Excel数据的读取和解析。 在Apache POI 3.8中,主要涉及以下核心概念: 1. **HSSF(Horrible Spreadsheet Format)**:这是Apache POI中处理旧版Excel...
1. Apache POI技术解析Excel文档: Apache POI是Apache软件基金会的开放源代码项目,它提供了用于读取和写入Microsoft Office格式文件的API。尤其是对于Excel文档,POI提供了两种主要的Excel文件格式支持,一种是...
【标题】"poi解析excel"涉及的是Java编程中使用Apache POI库来处理Microsoft Excel文件的知识。Apache POI是开源项目,提供了API用于读写Microsoft Office格式的文件,特别是Excel。在Java应用中,POI使得开发者能够...
标题“POI解析EXCEL分层”涉及到的主要知识点是Apache POI库在处理Microsoft Excel文件时的层次化数据解析。Apache POI是一个流行的开源Java API,它允许开发者读取、写入和修改Microsoft Office格式的文件,其中...
2. **使用Apache POI解析Excel**: - 创建工作簿对象:通过`WorkbookFactory.create()`方法,你可以根据文件路径创建一个表示Excel工作簿的对象,如`HSSFWorkbook`(BIFF8格式)或`XSSFWorkbook`(OOXML格式)。 -...
在这个"利用POI解析excel并存入数据库demo"中,我们将关注如何使用 POI 库来读取 Excel 文件,并将数据有效地存入 MySQL 数据库。 首先,要开始使用 POI,你需要在你的项目中引入相应的依赖。如果你使用的是 Maven...
标题“POI3.7Excel解析”提示我们将重点讨论使用Apache POI 3.7版本处理Excel文件的相关知识点。 1. **Apache POI简介** Apache POI 是Apache软件基金会的一个项目,它提供了Java API,使得开发者可以使用Java处理...
在Java环境中,使用Apache POI库解析Excel文件时,确实需要引入一系列的依赖包来确保所有必要的功能得以正常运行。这些包包含了对Excel文件格式的理解和支持,允许开发者读取、写入和修改Excel数据。 1. **Apache ...
在本示例中,我们将重点关注如何使用Apache POI 3.6版本解析Excel 2003(.xls)文件。Excel 2003文件使用的是HSSF(Horrible Spreadsheet Format)API,它是POI项目早期版本支持的老式Excel格式。 Apache POI 提供...
使用Apache POI解析Excel数据的基本步骤如下: 1. **添加依赖**:将对应的poi.jar包引入项目类路径。如果是Maven项目,可以在pom.xml文件中添加依赖项,如下: ```xml <groupId>org.apache.poi <artifactId>...
Java使用poi的jar包解析excel,里面有个ExcelUtil工具类, 非常实用,里面有main函数可以测试,导入到eclipse里面就可以运行, 有测试excel文件,需要的jar都在里面, 导入就可以运行.
本示例将深入讲解如何使用Apache POI来解析Excel文件。 Apache POI是Apache软件基金会的一个开源项目,它的主要功能是处理微软的Office Open XML (OOXML) 和早期的二进制文件格式,例如Excel的.BIFF8格式。在Java中...