Java-读取excel单元格数据

Java代码

  poi读取表格数据的时候是先读行再读列,jxl读取excel数据时是先读列再读行

import org.apache.poi.hssf.usermodel.HSSFRichTextString;
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;

import java.io.*;

public class TestDemo {
    public static void main(String[] args) {
        String path="C:\\Users\\82606\\Desktop\\0428\\test.xlsx";
         readExcel(path);
    }
    public static void readExcel(String path){
        try{
            InputStream inputStream=new FileInputStream(path);
            Workbook workbook=null;
            if(path.substring(path.lastIndexOf(".")+1).equals("xls")){
                workbook=new HSSFWorkbook(inputStream);
            }else if(path.substring(path.lastIndexOf(".")+1).equals("xlsx")){
                workbook=new XSSFWorkbook(inputStream);
            }

            //获取第一张表
            Sheet sheet=workbook.getSheetAt(0);
            for(int i=0;i<sheet.getPhysicalNumberOfRows();i++){
                //循环读取每一个格
                 Row row= sheet.getRow(i);
                 String id="";
                 for(int index=0;index<row.getPhysicalNumberOfCells();index++){
                     Cell cell= row.getCell(index);
                     //处理单元格中空单元格导致的空指针异常
                     if (cell==null){
                         cell= row.createCell(index);
                     }
                     id=cell.getStringCellValue();
                     System.out.println(id);
                 }

            }
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }

    }
}

pom.xml依赖

<dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>3.8.1</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.apache.directory.studio</groupId>
            <artifactId>org.apache.commons.codec</artifactId>
            <version>1.8</version>
        </dependency>
        <dependency>
            <groupId>net.sourceforge.jexcelapi</groupId>
            <artifactId>jxl</artifactId>
            <version>2.6.12</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>3.9</version>
        </dependency>
    </dependencies>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值