java读取Excel文件并解析

1、maven引入jar包

		<dependency>
			<groupId>org.apache.poi</groupId>
			<artifactId>poi</artifactId>
			<version>3.17</version>
		</dependency>

		<dependency>
			<groupId>org.apache.poi</groupId>
			<artifactId>poi-ooxml</artifactId>
			<version>3.15</version>
		</dependency>

2、测试类

package com.xd.excel;

import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

public class TestExcel {
	
	public static void main(String[] args) {
		//读取文件,返回一个Workbook对象
		Workbook wb = getExcel("D:/iotest/test.xlsx");
		
		if(wb == null) {
			System.out.println("文件读取错误!");
		}else {
			//解析
			parseExcel(wb);
		}
		
	}

	/**
	 * 	解析Excel
	 * @param wb
	 */
	private static void parseExcel(Workbook wb) {
		//解析excel
		Sheet sheet = wb.getSheetAt(0);//读取sheet,从0开始
		int rowNum = sheet.getLastRowNum();//读取行数,从0计数
		for(int i = 0; i <= rowNum; i++) {
			//获得行
			Row row = sheet.getRow(i);
			//获得当前行的列数
			int colNum = row.getLastCellNum();
			for(int j = 0; j < colNum; j++) {
				//获取单元格
				Cell cell = row.getCell(j);
				if(cell == null) {
					System.out.print("null ");
				}else {
					System.out.print(cell.toString()+" ");
				}
			}
			//换行
			System.out.println();
		}
		
		
	}

	/**
	 * 	读取Excel
	 * @param wb
	 */
	private static Workbook getExcel(String filePath) {
		Workbook wb = null;
		
		//封装文件路径
		File file = new File(filePath);
		
		//判断文件是否存在
		if(!file.exists()) {
			System.out.println("文件不存在!");
			return wb;
		}
		
		
		try {
			//文件存在,读取文件
			InputStream is = new FileInputStream(file);
			//获取文件后缀
			String fileSuffix = filePath.substring(filePath.lastIndexOf("."));
			//后缀是xls
			if(".xls".equals(fileSuffix)) {
				wb = new HSSFWorkbook(is);
			}else if(".xlsx".equals(fileSuffix)) {
				wb = new XSSFWorkbook(is);
			}else {
				System.out.println("文件格式不正确!");
			}
		} catch (Exception e) {
			e.printStackTrace();
			return wb;
		}
		
		//返回
		return wb;

	}

}

3、结果

在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值