java编程实现读取xlsx表格中指定数据

1.项目需求

读取Excel文件的内容,并返回所需的数据。如读取一下表中的姓名和身份证数据。

2.代码示例

导入maven库

读取Excel文件可以通过Apache POI库实现。

首先,在项目中引入Apache POI库

<dependencies>
    <!-- Apache POI dependencies -->
    <dependency>
        <groupId>org.apache.poi</groupId>
        <artifactId>poi</artifactId>
        <version>5.2.3</version>
    </dependency>
    <dependency>
        <groupId>org.apache.poi</groupId>
        <artifactId>poi-ooxml</artifactId>
        <version>5.2.3</version>
    </dependency>
    <dependency>
        <groupId>org.apache.poi</groupId>
        <artifactId>poi-ooxml-schemas</artifactId>
        <version>4.1.2</version>
    </dependency>
    <dependency>
        <groupId>org.apache.commons</groupId>
        <artifactId>commons-collections4</artifactId>
        <version>4.4</version>
    </dependency>
</dependencies>

编写实体类

public class Person {
        private String name;
        private String idNumber;

        public Person(String name, String idNumber) {
            this.name = name;
            this.idNumber = idNumber;
        }

        public String getName() {
            return name;
        }

        public String getIdNumber() {
            return idNumber;
        }

        @Override
        public String toString() {
            return "Person{name='" + name + "', idNumber='" + idNumber + "'}";
        }
    }

编写读取文件的工具类

public class readFrleUitl{

    public List<Person> readExcel(String FilePath){
        List<Person> personList =new ArrayList<>();

        try(FileInputStream fis = new FileInPitStream(filePath);
             Workbook workbook = new XSSFWorkbook(fis)) {
            
            Sheet sheet = workbook.getSheetAt(0); // 数据在第一个sheet中
            for (Row row : sheet) {
                Cell nameCell = row.getCell(2); // 姓名在第3列
                Cell idNumberCell = row.getCell(3); // 身份证号在第4列

                if (nameCell != null && idNumberCell != null) {
                    String name = nameCell.getStringCellValue();
                    String idNumber = idNumberCell.getStringCellValue();
                    personList.add(new Person(name, idNumber));
                }
            } catch (IOExceprion e) {
                e.printStackTrace();
            }
            
            return personList;
        }
}

编写测试方法

public static void main(String[] args) {
        String filePath = "/mnt/data/*****.xlsx";
        List<Person> personList = readExcel(filePath);

        for (Person person : personList) {
            System.out.println(person);
        }
    }
  • 4
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值