打造自己的读取Excel数据的工具类

本文介绍了一种使用Java读取Excel文件的方法,包括读取表头和内容,并提供了完整的代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在实际应用中经常需要把Excel表格数据导入到数据库,为此需求本人写了一个读取Excel数据的java类,现将代码贴出来与大家一起分享。

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

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

代码如下:

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

评论
alert008 2008-07-11 回复
public static String readXls(String path) throws Exception {
StringBuffer content = new StringBuffer("");// 文档内容
HSSFWorkbook workbook = new HSSFWorkbook(new FileInputStream(path));
int sheetCount = workbook.getNumberOfSheets();// excel几张表
for (int i = 0; i < sheetCount; i++) {// 遍历excel表
HSSFSheet sheet = workbook.getSheetAt(i);// 对excel的第一个表引用
int rowCount = sheet.getLastRowNum();// 取得最后一行的下标
for (int j = 0; j < rowCount; j++) {// 循环每一行
HSSFRow row = sheet.getRow(j);// 引用行
if (row == null) {
continue;
} else {
short cellNum = row.getLastCellNum();
for (short m = 0; m < cellNum; m++) {
HSSFCell cell = row.getCell(m);// 引用行中的一个单元格
if (cell != null) {
int cellType = cell.getCellType();
// CELL_TYPE_NUMERIC 0 数字
// CELL_TYPE_STRING 1 字符串
// CELL_TYPE_FORMULA 2 公式
// CELL_TYPE_BLANK 3 空格
// CELL_TYPE_BOOLEAN 4 布尔值
// CELL_TYPE_ERROR 5 错误
switch (cellType) {
// 单元格类型为数字
case HSSFCell.CELL_TYPE_NUMERIC:
// 取数字单元格的值
double d = cell.getNumericCellValue();
content.append(String.valueOf(d) + " ");
break;
// 单元格类型为字符串
case HSSFCell.CELL_TYPE_STRING:
String str = cell.getStringCellValue().trim();
if (!str.equals("")) {
content.append(str + " ");
}
break;
// 单元格类型为公式
case HSSFCell.CELL_TYPE_FORMULA:
// 不读取公式
// String formula = cell.getCellFormula();
// content = content + formula+" ";
break;
// 单元格类型为空白
case HSSFCell.CELL_TYPE_BLANK:
break;
// 单元格类型为布尔值
case HSSFCell.CELL_TYPE_BOOLEAN:
// boolean bool = cell.getBooleanCellValue();
// content = content + bool+" ";
break;
// 单元格类型为错误
case HSSFCell.CELL_TYPE_ERROR:
// byte errorCode = cell.getErrorCellValue();
// content = content + errorCode+" ";
break;
default:
break;
}
} else {
// content = content + "..." +" ";//没有数据的单元格使用...填充
}
}
}
content.append("\r");
}
}
return content.toString().trim();
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值