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

需要用到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 不区分大小写
. 任意的意思

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

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值