`
fjfj910
  • 浏览: 89018 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

读取excel数据的java类

阅读更多

在项目中用户需要导入大量Excel表格数据到数据库,为此需求自己写了一个读取Excel数据的java类,现将代码贴出来与大家一起分享。

该类提供两个方法,一个方法用于读取Excel表格的表头,另一个方法用于读取Excel表格的内容。

(注:本类需要POI组件的支持,POI是apache组织下的一个开源组件,)

代码如下:

Java代码 复制代码
  1. package org.hnylj.poi.util;   
  2.   
  3. import java.io.FileInputStream;   
  4. import java.io.FileNotFoundException;   
  5. import java.io.IOException;   
  6. import java.io.InputStream;   
  7. import java.util.Date;   
  8. import java.util.HashMap;   
  9. import java.util.Map;   
  10.   
  11. import org.apache.poi.hssf.usermodel.HSSFCell;   
  12. import org.apache.poi.hssf.usermodel.HSSFRow;   
  13. import org.apache.poi.hssf.usermodel.HSSFSheet;   
  14. import org.apache.poi.hssf.usermodel.HSSFWorkbook;   
  15. import org.apache.poi.poifs.filesystem.POIFSFileSystem;   
  16.   
  17. /**  
  18.  * 操作Excel表格的功能类  
  19.  * @author:hnylj  
  20.  * @version 1.0  
  21.  */  
  22. public class ExcelReader {   
  23.     private POIFSFileSystem fs;   
  24.     private HSSFWorkbook wb;   
  25.     private HSSFSheet sheet;   
  26.     private HSSFRow row;   
  27.     /**  
  28.      * 读取Excel表格表头的内容  
  29.      * @param InputStream  
  30.      * @return String 表头内容的数组  
  31.      *   
  32.      */  
  33.     public String[] readExcelTitle(InputStream is) {   
  34.         try {   
  35.             fs = new POIFSFileSystem(is);   
  36.             wb = new HSSFWorkbook(fs);   
  37.         } catch (IOException e) {   
  38.             e.printStackTrace();   
  39.         }   
  40.         sheet = wb.getSheetAt(0);   
  41.         row = sheet.getRow(0);   
  42.         //标题总列数   
  43.         int colNum = row.getPhysicalNumberOfCells();   
  44.         String[] title = new String[colNum];   
  45.         for (int i=0; i<colNum; i++) {   
  46.             title[i] = getStringCellValue(row.getCell((short) i));   
  47.         }   
  48.         return title;   
  49.     }   
  50.        
  51.     /**  
  52.      * 读取Excel数据内容  
  53.      * @param InputStream  
  54.      * @return Map 包含单元格数据内容的Map对象  
  55.      */  
  56.     public Map<Integer,String> readExcelContent(InputStream is) {   
  57.         Map<Integer,String> content = new HashMap<Integer,String>();   
  58.         String str = "";   
  59.         try {   
  60.             fs = new POIFSFileSystem(is);   
  61.             wb = new HSSFWorkbook(fs);   
  62.         } catch (IOException e) {   
  63.             e.printStackTrace();   
  64.         }   
  65.         sheet = wb.getSheetAt(0);   
  66.         //得到总行数   
  67.         int rowNum = sheet.getLastRowNum();   
  68.         row = sheet.getRow(0);   
  69.         int colNum = row.getPhysicalNumberOfCells();   
  70.         //正文内容应该从第二行开始,第一行为表头的标题   
  71.         for (int i = 1; i <= rowNum; i++) {   
  72.             row = sheet.getRow(i);   
  73.             int j = 0;   
  74.             while (j<colNum) {   
  75.         //每个单元格的数据内容用"-"分割开,以后需要时用String类的replace()方法还原数据   
  76.         //也可以将每个单元格的数据设置到一个javabean的属性中,此时需要新建一个javabean   
  77.                 str += getStringCellValue(row.getCell((short) j)).trim() + "-";   
  78.                 j ++;   
  79.             }   
  80.             content.put(i, str);   
  81.             str = "";   
  82.         }   
  83.         return content;   
  84.     }   
  85.        
  86.     /**  
  87.      * 获取单元格数据内容为字符串类型的数据  
  88.      * @param cell Excel单元格  
  89.      * @return String 单元格数据内容  
  90.      */  
  91.     private String getStringCellValue(HSSFCell cell) {   
  92.         String strCell = "";   
  93.         switch (cell.getCellType()) {   
  94.         case HSSFCell.CELL_TYPE_STRING:   
  95.             strCell = cell.getStringCellValue();   
  96.             break;   
  97.         case HSSFCell.CELL_TYPE_NUMERIC:   
  98.             strCell = String.valueOf(cell.getNumericCellValue());   
  99.             break;   
  100.         case HSSFCell.CELL_TYPE_BOOLEAN:   
  101.             strCell = String.valueOf(cell.getBooleanCellValue());   
  102.             break;   
  103.         case HSSFCell.CELL_TYPE_BLANK:   
  104.             strCell = "";   
  105.             break;   
  106.         default:   
  107.             strCell = "";   
  108.             break;   
  109.         }   
  110.         if (strCell.equals("") || strCell == null) {   
  111.             return "";   
  112.         }   
  113.         if (cell == null) {   
  114.             return "";   
  115.         }   
  116.         return strCell;   
  117.     }   
  118.        
  119.     /**  
  120.      * 获取单元格数据内容为日期类型的数据  
  121.      * @param cell Excel单元格  
  122.      * @return String 单元格数据内容  
  123.      */  
  124.     private String getDateCellValue(HSSFCell cell) {   
  125.         String result = "";   
  126.         try {   
  127.             int cellType = cell.getCellType();   
  128.             if (cellType == HSSFCell.CELL_TYPE_NUMERIC) {   
  129.                 Date date = cell.getDateCellValue();   
  130.                 result = (date.getYear() + 1900) + "-" + (date.getMonth() + 1)    
  131.                 + "-" + date.getDate();   
  132.             } else if (cellType == HSSFCell.CELL_TYPE_STRING) {   
  133.                 String date = getStringCellValue(cell);   
  134.                 result = date.replaceAll("[年月]""-").replace("日""").trim();   
  135.             } else if (cellType == HSSFCell.CELL_TYPE_BLANK) {   
  136.                 result = "";   
  137.             }   
  138.         } catch (Exception e) {   
  139.             System.out.println("日期格式不正确!");   
  140.             e.printStackTrace();   
  141.         }   
  142.         return result;   
  143.     }   
  144.        
  145.     public static void main(String[] args) {   
  146.         try {   
  147.             //对读取Excel表格标题测试   
  148.             InputStream is = new FileInputStream("C:\\Excel表格测试.xls");   
  149.             ExcelReader excelReader = new ExcelReader();   
  150.             String[] title = excelReader.readExcelTitle(is);   
  151.             System.out.println("获得Excel表格的标题:");   
  152.             for (String s : title) {   
  153.                 System.out.print(s + " ");   
  154.             }   
  155.                
  156.             //对读取Excel表格内容测试   
  157.             InputStream is2 = new FileInputStream("C:\\Excel表格测试.xls");   
  158.             Map<Integer,String> map = excelReader.readExcelContent(is2);   
  159.             System.out.println("获得Excel表格的内容:");   
  160.             for (int i=1; i<=map.size(); i++) {   
  161.                 System.out.println(map.get(i));   
  162.             }   
  163.         } catch (FileNotFoundException e) {   
  164.             System.out.println("未找到指定路径的文件!");   
  165.             e.printStackTrace();   
  166.         }   
  167.     }   
  168. }  
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 读取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读取Excel内容

    Java读取Excel内容 v Java读取Excel内容 Java读取Excel内容

    java读取excel数据导入数据库源码

    java读取excel数据导入数据库源码 java读取excel数据导入数据库源码

    用Java程序读取Excel表格内容并显示在Swing中

    在Java编程环境中,读取Excel表格内容并将其展示在Swing界面是一项常见的任务,尤其在数据处理和报表展示方面。本篇文章将详细讲解如何实现这一功能。 首先,我们需要引入两个关键库:Apache POI用于读取Excel文件...

    读取Excel表格数据写入Word

    java实现读取Excel数据,根据一定格式写入Word,包含源代码,所需jar包及打包后的可执行jar文件,解压后将ExcelTrans直接导入MyEclipse即可,项目上可能会出现一个小叉,但是可以正常运行。

    java读取excel文件

    本文将详细介绍如何使用Java通过JExcelApi库来读取Excel文件中的数据。 #### 二、JExcelApi简介 JExcelApi是一个用于读写Microsoft Excel文件的Java类库,支持读取和写入.xls文件。它提供了丰富的API来处理Excel...

    java批量读取Excel表格

    Java批量读取Excel表格是一种常见的数据处理需求,特别是在大数据导入、报表生成或数据分析场景中。在Java中,我们可以借助Apache POI库来实现这一功能。Apache POI是一个强大的开源库,它允许Java开发者读写...

    Android开发之读取Excel表格数据

    本篇文章将详细讲解如何在Android环境中直接读取资源文件夹下的Excel表格数据,为你的应用提供便捷的数据处理能力。 首先,理解Android的资源文件夹结构是至关重要的。在Android Studio项目中,我们通常把静态的非...

    C#中读取Excel表格数据实例

    本文将深入探讨如何在C#中实现无依赖于Microsoft Office的情况下读取Excel表格数据,主要关注以下几个方面:使用开源库、操作Excel文件格式以及优化性能。 首先,C#本身并不内置读取Excel的API,因此我们需要借助第...

    java读取excel数据!

    本示例中,我们关注的是如何使用Java来读取Excel表格中的数据,并将其保存,这通常涉及到Apache POI库的应用。Apache POI是一个开源项目,提供了处理Microsoft Office格式文档(如Excel)的能力。 首先,确保你已经...

    Java读取Excel表格中的日期

    ### Java读取Excel表格中的日期 #### 背景与问题描述 在处理Excel文件时,经常遇到的一个问题是如何正确地识别并处理日期格式的数据。这是因为Excel中的日期格式较为复杂,有时甚至会出现不同版本的Excel文件中...

    java读取excel

    Java 读取 Excel 文件是 Java 语言中常见的操作之一,通过使用 Apache POI 库,可以轻松地读取 Excel 文件中的数据。本文将通过 ReadExcelUtil 工具类,详细介绍如何读取 Excel 文件。 读取 Excel 文件 ...

    Java读取Excel表格数据时(.xls、.xlsx 格式),需要引用的jar包

    总结起来,Java读取Excel数据涉及的主要知识点有:Apache POI库的使用,包括`.xls`和`.xlsx`格式的处理;Android环境下的兼容性考虑,可能需要使用`jxl`库;以及如何通过Java代码遍历Excel文件的行和单元格,获取并...

    完美解决java读取excel内存溢出问题.rar

    总结来说,解决Java读取Excel内存溢出问题,关键在于合理利用资源、优化代码逻辑以及选择适合的API,如Apache POI的SXSSF。通过这些方法,我们可以在不显著增加系统资源负担的情况下,高效地处理大Excel文件。

    JAVA读取Excel,建库建表,并生成java实体

    该项目可能包括读取Excel、解析数据、创建数据库表和生成Java实体类的相关类和脚本。你可以下载并查看该项目的源代码,了解具体的实现细节。 总结,Java读取Excel并进行数据库建库建表及生成Java实体的过程涉及了...

    Java 读取 excel数据

    在Java编程环境中,读取Excel数据是一项常见的任务,特别是在数据处理、数据分析或自动化报表生成的场景下。本项目提供了一种实现方式,包含了测试数据和必要的库文件,确保可以直接运行并成功读取Excel数据。 首先...

    java读取Excel中得数据

    代码是借助于apathe的poi.jar实现得读取excel内得数据,所以在应用程序中添加poi.jar包,并将需要读取的excel文件放入根目录即可。路径可以自行修改成绝对路径,一共需要用到得几个jar,都放在文件夹里面。

    java上传并读取excel工具类

    3. **读取Excel文件**: 使用Apache POI,我们可以通过`XSSFWorkbook`(对于.xlsx)或`HSSFWorkbook`(对于.xls)来打开Excel文件。以下是一个简单的示例: ```java Workbook workbook = new XSSFWorkbook(new ...

    java/jsp读取Excel的数据,并返回List

    java/jsp读取Excel的数据, 并返回List(jar包请搜索“读取Excel的数据jar poi”)

Global site tag (gtag.js) - Google Analytics