【判断一个文件是否为 excel 文件的正则表达式】

本文介绍如何利用Java中的String类matches方法和正则表达式来判断并读取不同版本的Excel文件(.xls和.xlsx)。通过具体代码示例展示了如何根据文件后缀名确定文件类型,并选择合适的工作簿对象进行读取。

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

需要用到String类的matches(),boolean matches(String regex),判断字符串是否与给定的正则表达式匹配。

// 例:读取03和07版本的excel
String fileNameAndPath = "e:\\测试.xls";
if ( fileNameAndPath.matches("^.+\\.(?i)((xls)|(xlsx))$") ){
    // 得到文件输入流对象
    FileInputStream inputStream = new FileInputStream(fileNameAndPath);
    boolean is03Excel = fileNameAndPath.matches( "^.+\\.(?i)(xls)$" );
    // 创建工作簿,并传递要读取的文件
    Workbook workBook = is03Excel ? new HSSFWorkbook(inputStream) : new XSSFWorkbook(inputStream); //HSSFWorkbook和XSSFWorkbook都实现了Workbook接口
    // 得到工作表,并读取
    Sheet sheet = workBook.getSheetAt(0);
    // 得到行,并读取
    Row row = sheet.getRow(2);
    // 得到单元格,并读取单元格
    Cell cell = row.getCell(2);
    System.out.println("C3单元格的内容是:" + cell.getStringCellValue());
    workBook.close();
    inputStream.close();
}

上面代码用到的正则表达式解释如下:

^ 匹配输入字符串的开始位置
$ 匹配输入字符串的结束位置
| 或者的意思
?i 不区分大小写
. 任意的意思

开始位置后面的 . 代表任意路径任意文件名称;+ 后面的 . 是文件类型的固定后缀,所以是特殊字符,因为在正则表达式 . 代表任意的意思,所以需要用到转义字符 \ ,而 \ 又是特殊字符,再去用 \ 去转

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值