poi读取Excel

本文提供了一个使用Apache POI库读取并解析Excel文件的示例代码,包括文件路径读取、工作簿获取、工作表遍历以及单元格值的格式化处理。

        本文为poi生成Excel的序章。

        示例代码如下所示:

/**
 * 
 */
package com.geloin.poi.main;

import java.io.FileInputStream;
import java.math.BigDecimal;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
import java.util.Iterator;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFDateUtil;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;

/**
 * @author Geloin
 * 
 */
public class PoiReadExcel {

	/**
	 * @param args
	 */
	public static void main(String[] args) throws Exception {
		String filePath = "d:/work/proTmp/geloin/poi/export.xls";
		POIFSFileSystem fs = new POIFSFileSystem(new FileInputStream(filePath));
		HSSFWorkbook workBook = new HSSFWorkbook(fs);
		HSSFSheet sheet = workBook.getSheetAt(0);
		Iterator<Row> it = sheet.rowIterator();
		while (it.hasNext()) {
			Row row = it.next();
			int cellCount = row.getPhysicalNumberOfCells();
			for (int i = 0; i < cellCount; i++) {
				Cell cell = row.getCell(i);
				String cellValue = getCellFormatValue(cell);
				System.out.print(cellValue + "\t\t");
			}
			System.out.println();
		}
	}

	/**
	 * 根据HSSFCell类型设置数据
	 * 
	 * @param cell
	 * @return
	 */
	private static String getCellFormatValue(Cell cell) {
		String cellvalue = "";
		if (cell != null) {
			// 判断当前Cell的Type
			switch (cell.getCellType()) {
			// 如果当前Cell的Type为NUMERIC
			case HSSFCell.CELL_TYPE_FORMULA: {
				// 判断当前的cell是否为Date
				if (HSSFDateUtil.isCellDateFormatted(cell)) {
					// 如果是Date类型则,转化为Data格式
					Date date = cell.getDateCellValue();
					SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
					cellvalue = sdf.format(date);

				} else {
					// 如果是纯数字
					// 取得当前Cell的数值
					BigDecimal big = new BigDecimal(cell.getNumericCellValue());
					cellvalue = String.valueOf(big.longValue());
				}
				break;
			}
			case HSSFCell.CELL_TYPE_NUMERIC: {
				// 假设为日期型
				Date date = cell.getDateCellValue();
				Calendar c = Calendar.getInstance();
				c.setTime(date);
				if (c.get(Calendar.YEAR) > 1900
						&& String.valueOf(c.get(Calendar.YEAR)).length() == 4) {
					// 如果年大于1900且年的长度等于4,此处是不严格的处理,当年度为1900时,就会出错,目前没有找到更好的解决办法
					SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
					cellvalue = sdf.format(date);
				} else {
					cellvalue = String.valueOf(cell.getNumericCellValue());
					if (!cellvalue.matches("\\d+\\.\\d+")) {
						// 如果不是double,则转一下
						BigDecimal big = new BigDecimal(
								cell.getNumericCellValue());
						cellvalue = String.valueOf(big.longValue());
					}
					// 如果是double,返回结果。
				}
				break;
			}
			// 如果当前Cell的Type为STRIN
			case HSSFCell.CELL_TYPE_STRING:
				// 取得当前的Cell字符串
				cellvalue = cell.getRichStringCellValue().getString();
				break;
			// 默认的Cell值
			default:
				cellvalue = " ";
			}
		} else {
			cellvalue = "";
		}
		return cellvalue;

	}
}

        getCellFormatValue方法应该为一个较为通用的方法,可写在工具类中。

        代码比较简单,不再赘述。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值