读取excel时遇到的单元格是日期或百分比格式问题.

本文介绍了在处理Excel数据时如何判断和转换单元格格式。通过使用Apache POI库,我们可以获取CellType枚举来确定单元格类型,如数值型、字符串型、公式型等。对于日期格式,可以使用SimpleDateFormat转换为字符串;百分比格式则可以通过HSSFDataFormatter进行格式化。了解这些技巧能帮助我们更有效地读取和处理Excel中的各种数据。

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

  • 当我们在读取excel表格数据时,经常会遇到单元格的格式问题,不同的单元格格式取值方式也不同.获取到单元格之后首先要对单元格格式进行判断:
 //获取cell的类型
int type = cell.getCellType();
  • CellType是一个枚举类,主要有以下类型:
public enum CellType {
    @Internal(
        since = "POI 3.15 beta 3"
    )
    _NONE(-1),
    NUMERIC(0),  //数值型
    STRING(1),  //字符串型
    FORMULA(2),  //公式型
    BLANK(3),  //空值
    BOOLEAN(4),  //布尔型
    ERROR(5);  //错误
  • 可以转换单元格的格式
cell.setCellType(CellType.STRING);
cell.getStringCellValue().trim();
  • 如图所示: 当单元格是日期格式时:
    在这里插入图片描述
//获取日期
String date = new SimpleDateFormat("yyyy-MM").format(cell.getDateCellValue());
  • 当单元格是百分比格式时:
 HSSFDataFormatter dataFormatter = new HSSFDataFormatter();
String number = dataFormatter.formatCellValue(cell);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值