java poi 获取Excel中所有列名

该代码片段展示了如何利用Java POI库读取Excel文件并获取所有工作表的名称。首先,验证文件是否为有效Excel文件,然后根据文件类型(Excel 2003或2007)创建相应的Workbook对象。接着,遍历所有工作表,将工作表名称添加到列表中。最后关闭输入流。这个方法适用于处理包含多个工作表的Excel文件。

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

java poi 获取Excel中所有列名

下面展示一些 内联代码片

    /**
     * 获取所有列名
     * @param filePath
     * @return
     */
    public List<String> getSheets(String filePath) {
        List<String> sheetList = new ArrayList<>();
        InputStream is = null;
        try {
            /** 验证文件是否合法 */
            if (!validateExcel(filePath)) {
                System.out.println(errorInfo);
                return null;
            }
            /** 判断文件的类型,是2003还是2007 */
            boolean isExcel2003 = true;
            if (WDWUtil.isExcel2007(filePath)) {
                isExcel2003 = false;
            }
            /** 调用本类提供的根据流读取的方法 */
            File file = new File(filePath);
            is = new FileInputStream(file);
            /** 根据版本选择创建Workbook的方式 */
            Workbook wb = null;
            if (isExcel2003) {
                wb = new HSSFWorkbook(is);
            } else {
                wb = new XSSFWorkbook(is);
            }
            if (wb != null) {
                int numberOfSheets = wb.getNumberOfSheets();
                if (numberOfSheets > 0) {
                    for (int i = 0; i < numberOfSheets; i++) {
                        String sheetName = wb.getSheetName(i);
                        sheetList.add(sheetName);
                    }
                }
            }
            is.close();
        } catch (Exception ex) {
            ex.printStackTrace();
        } finally {
            if (is != null) {
                try {
                    is.close();
                } catch (IOException e) {
                    is = null;
                    e.printStackTrace();
                }
            }
        }
        return sheetList;
    }
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值