在实际应用中经常需要把Excel表格数据导入到数据库,为此需求本人写了一个读取Excel数据的java类,现将代码贴出来与大家一起分享。
该类提供两个方法,一个方法用于读取Excel表格的表头,另一个方法用于读取Excel表格的内容。
(注:本类需要POI组件的支持,POI是apache组织下的一个开源组件,)
代码如下:
package org.hnylj.poi.util; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; import java.io.InputStream; import java.util.Date; import java.util.HashMap; 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 org.apache.poi.poifs.filesystem.POIFSFileSystem; /** * 操作Excel表格的功能类 * @author:hnylj * @version 1.0 */ public class ExcelReader { private POIFSFileSystem fs; private HSSFWorkbook wb; private HSSFSheet sheet; private HSSFRow row; /** * 读取Excel表格表头的内容 * @param InputStream * @return String 表头内容的数组 * */ public String[] readExcelTitle(InputStream is) { try { fs = new POIFSFileSystem(is); wb = new HSSFWorkbook(fs); } catch (IOException e) { e.printStackTrace(); } sheet = wb.getSheetAt(0); row = sheet.getRow(0); //标题总列数 int colNum = row.getPhysicalNumberOfCells(); String[] title = new String[colNum]; for (int i=0; i<colNum; i++) { title[i] = getStringCellValue(row.getCell((short) i)); } return title; } /** * 读取Excel数据内容 * @param InputStream * @return Map 包含单元格数据内容的Map对象 */ public Map<Integer,String> readExcelContent(InputStream is) { Map<Integer,String> content = new HashMap<Integer,String>(); String str = ""; try { fs = new POIFSFileSystem(is); wb = new HSSFWorkbook(fs); } catch (IOException e) { e.printStackTrace(); } sheet = wb.getSheetAt(0); //得到总行数 int rowNum = sheet.getLastRowNum(); row = sheet.getRow(0); int colNum = row.getPhysicalNumberOfCells(); //正文内容应该从第二行开始,第一行为表头的标题 for (int i = 1; i <= rowNum; i++) { row = sheet.getRow(i); int j = 0; while (j<colNum) { //每个单元格的数据内容用"-"分割开,以后需要时用String类的replace()方法还原数据 //也可以将每个单元格的数据设置到一个javabean的属性中,此时需要新建一个javabean str += getStringCellValue(row.getCell((short) j)).trim() + "-"; j ++; } content.put(i, str); str = ""; } return content; } /** * 获取单元格数据内容为字符串类型的数据 * @param cell Excel单元格 * @return String 单元格数据内容 */ private String getStringCellValue(HSSFCell cell) { String strCell = ""; switch (cell.getCellType()) { case HSSFCell.CELL_TYPE_STRING: strCell = cell.getStringCellValue(); break; case HSSFCell.CELL_TYPE_NUMERIC: strCell = String.valueOf(cell.getNumericCellValue()); break; case HSSFCell.CELL_TYPE_BOOLEAN: strCell = String.valueOf(cell.getBooleanCellValue()); break; case HSSFCell.CELL_TYPE_BLANK: strCell = ""; break; default: strCell = ""; break; } if (strCell.equals("") || strCell == null) { return ""; } if (cell == null) { return ""; } return strCell; } /** * 获取单元格数据内容为日期类型的数据 * @param cell Excel单元格 * @return String 单元格数据内容 */ private String getDateCellValue(HSSFCell cell) { String result = ""; try { int cellType = cell.getCellType(); if (cellType == HSSFCell.CELL_TYPE_NUMERIC) { Date date = cell.getDateCellValue(); result = (date.getYear() + 1900) + "-" + (date.getMonth() + 1) + "-" + date.getDate(); } else if (cellType == HSSFCell.CELL_TYPE_STRING) { String date = getStringCellValue(cell); result = date.replaceAll("[年月]", "-").replace("日", "").trim(); } else if (cellType == HSSFCell.CELL_TYPE_BLANK) { result = ""; } } catch (Exception e) { System.out.println("日期格式不正确!"); e.printStackTrace(); } return result; } public static void main(String[] args) { try { //对读取Excel表格标题测试 InputStream is = new FileInputStream("C:\\Excel表格测试.xls"); ExcelReader excelReader = new ExcelReader(); String[] title = excelReader.readExcelTitle(is); System.out.println("获得Excel表格的标题:"); for (String s : title) { System.out.print(s + " "); } //对读取Excel表格内容测试 InputStream is2 = new FileInputStream("C:\\Excel表格测试.xls"); Map<Integer,String> map = excelReader.readExcelContent(is2); System.out.println("获得Excel表格的内容:"); for (int i=1; i<=map.size(); i++) { System.out.println(map.get(i)); } } catch (FileNotFoundException e) { System.out.println("未找到指定路径的文件!"); e.printStackTrace(); } } }
通过该类提供的方法就能读取出Excel表格中的数据,数据读取出来了,其他的,对这些数据进行怎样的操作,要靠你另外写程序去实现,因为该类只提供读取Excel表格数据的功能。
说明:在该类中有一个getStringCellValue(HSSFCell cell)方法和一个getDateCellValue(HSSFCell cell)方法,前一个方法用于读取那些为字符串类型的数据,如果你的Excel表格中填写的是日期类型的数据,则你应该在readExcelContent(InputStream is)方法里调用getDateCellValue(HSSFCell cell)方法,因为若调用getStringCellValue(HSSFCell cell)方法读取日期类型的数据将得到的是一个浮点数,这很可能不符合实际要求。
一个Java技术交流群,一起交流,共同进步,扣扣群号:513086638
相关推荐
总的来说,用VB打造自己的Excel表格编辑器是一项挑战性的工作,它涵盖了控件使用、数据处理、公式计算、图表绘制、文件操作等多个方面的VB编程知识。通过这个项目,开发者不仅可以深入理解VB的编程特性,还能提高...
本文将深入探讨如何在自己的应用中实现类似的功能,特别是关于Excel表格的部分。 首先,我们需要理解Excel表格的核心概念。Excel表格是由单元格构成的二维网格,每个单元格可以包含文本、数字或公式,并且单元格...
通过xlwings,它能够读取Excel文件,进行各种数据清洗、转换和分析操作,然后将结果返回到Excel或保存在其他数据格式中。数据处理是任何项目的核心,`data_utility.py`可能包含了各种数据科学方法,如统计分析、数据...
例如,你可以创建一个`ExcelExporter`类,包含方法如`ExportToExcel`,它接受数据集合并将其转换为Excel工作表。了解如何处理单元格样式、公式以及数据格式化是此类库的关键知识点。 3. 文件操作类:C#的System.IO...
《C# Winform实现问财数据获取与处理详解》 在信息技术日新月异的今天,数据已经成为企业和个人决策的重要...在实际应用中,可以根据需求进行扩展,比如增加图表展示、实时数据更新等,以打造更强大的财经信息工具。
在信息技术领域,数据的展示和分析是至关重要的,Excel作为一款强大的电子表格工具,被广泛应用于数据的整理和报表制作。然而,当需要自动化生成复杂的Excel报表时,手动操作的效率就显得低下,此时,结合Java编程...
《“java+poi+模板”打造复杂excel报表》 在Java开发中,生成复杂的Excel报表是一项常见的需求,尤其在数据分析、报表生成等领域。Apache POI库是Java中处理Microsoft Office格式文件的重要工具,它提供了对Excel...
《Unity游戏开发中的数据保存与恢复:Easy...通过深入学习和理解其原理,开发者可以更好地利用这一工具,打造更加稳定、高效的游戏。无论是新手还是经验丰富的开发者,都应该将其纳入工具箱,提升项目的质量和效率。
通过EXTJS,我们可以轻松地将表格数据导出为Excel文件,这在数据分析、报表生成或数据备份等方面非常有用。实现这一功能通常涉及读取Grid数据,转换为Excel兼容格式(如CSV或XML),然后利用浏览器的下载功能将数据...
通过操作这些对象,你可以实现对Excel数据的读取、修改和格式化。例如,Range对象的方法包括Value、Formula、ClearContents等,用于设置或获取单元格的值、公式或者清除内容。 另外,事件驱动编程是VBA的一大特色。...
课程会介绍如何使用Python读取各种格式(如CSV、Excel、数据库)的数据,并进行数据清洗,包括处理缺失值、异常值和重复值等。 4. 探索性数据分析(EDA):通过可视化工具如Matplotlib和Seaborn,学生可以学习如何...
例如,你可以使用它快速实现数据的读取和写入,只需要定义好对应的实体类和监听器,就能自动生成相应的Excel模板。此外,EasyExcel还支持自定义样式、公式处理等功能,满足了各种复杂的Excel处理需求。 在项目集成...
《NativeExcel v3 for Delphi:打造高效Excel处理能力》 在编程领域,尤其是在使用Delphi语言进行开发时,高效地处理Excel文件是一项常见的需求。NativeExcel v3 for Delphi作为一个强大的库,专为Delphi开发者提供...
数据可视化则讲解了数据可视化的概念、发展历程、技术分类和具体方法,以及如何使用Excel等工具进行数据的可视化呈现。 通过这个全面的课程系列,学生将能够掌握大数据的基本理论、关键技术以及实际应用,为理解和...
R提供了多种包如`readr`、`data.table`等用于读取CSV、Excel等格式的数据。数据预处理包括清洗(处理缺失值、异常值)、转换(标准化、归一化)和整合(合并多个数据源)等步骤,为后续分析打下坚实基础。 3. 探索...
首先,`PoiUtils.java`可能是一个工具类,用于封装POI操作,包括创建、写入和读取Excel文件等通用功能。在easyExcel中,自定义样式通常涉及到设置单元格的字体、颜色、边框、对齐方式、背景色等属性。`PoiUtils`可能...
标题中的“CAD坐标获取工具,VB控制CAD”指的是利用Visual Basic (VB)编程语言来操控AutoCAD软件,以便从AutoCAD中提取图形对象的坐标数据。这个过程涉及到多个IT知识点,包括计算机辅助设计(CAD)、编程接口(API)...