[excel]读取cell里数值的表现形式

目前在JAVA上记取excl, 是通过 poi 的 hssf 和 jxl
在读取数值时, 有一个情况是经常遇到的, 就是我们需要数值的表现形式, 而不是数值本身
例如, 7 1/4, 它的真实数值是 7.25, 你在上面菜单左侧单元格编号右边, "fx" 后面可以看见这个真实的值, 只是, 也许是客户不熟excel, 也许是业务原因, 总之, 我们在后台需要获取 "7 1/4", 而不是 "7.25",

hssf

cell.getNumberValue()


jxl

cell.getContents()

numberCell.getValue()

都是得到"7.25"

如果强制转化成 label 单元格, 将会抛出异常

解决办法

其实excel的单元格表现形式, 是有格式的, 7.25 要表现成 7 1/4, 实际上是通过设计格式为 "# ?/?", 只是excel"人性化"的自动帮我们做了这一步, 具体在: 单元格格式->数字->分类->自定义-> # ?/?

另外, 也等价于, 分类->分数->分母为一位数(1/4)

所以, 我们可以通过dataformat获知这个数值的格式, 再人为转化出这个数值的表现形式

实例

jxl

CellFormat cf=cell.getCellFormat();
Format f=cf.getFormat();
System.out.println("formula : "+f.getFormatString());

结果是: formula : # ?/?


poi

int df=cell.getCellStyle().getDataFormat();
System.out.println("formula : "+df);

结果是: formula : 12

这个值参考 dataformat, 为方便浏览, 我贴出来:

0, "General"
1, "0"
2, "0.00"
3, "#,##0"
4, "#,##0.00"
5, "($#,##0_);($#,##0)"
6, "($#,##0_);[Red]($#,##0)"
7, "($#,##0.00);($#,##0.00)"
8, "($#,##0.00_);[Red]($#,##0.00)"
9, "0%"
0xa, "0.00%"
0xb, "0.00E+00"
0xc, "# ?/?"
0xd, "# ??/??"
0xe, "m/d/yy"
0xf, "d-mmm-yy"
0x10, "d-mmm"
0x11, "mmm-yy"
0x12, "h:mm AM/PM"
0x13, "h:mm:ss AM/PM"
0x14, "h:mm"
0x15, "h:mm:ss"
0x16, "m/d/yy h:mm"

// 0x17 - 0x24 reserved for international and undocumented 0x25, "(#,##0_);(#,##0)"

0x26, "(#,##0_);[Red](#,##0)"

0x27, "(#,##0.00_);(#,##0.00)"

0x28, "(#,##0.00_);[Red](#,##0.00)"

0x29, "_(*#,##0_);_(*(#,##0);_(* \"-\"_);_(@_)"

0x2a, "_($*#,##0_);_($*(#,##0);_($* \"-\"_);_(@_)"

0x2b, "_(*#,##0.00_);_(*(#,##0.00);_(*\"-\"??_);_(@_)"

0x2c, "_($*#,##0.00_);_($*(#,##0.00);_($*\"-\"??_);_(@_)"

0x2d, "mm:ss"

0x2e, "[h]:mm:ss"

0x2f, "mm:ss.0"

0x30, "##0.0E+0"

0x31, "@" - This is text format.

0x31 "text" - Alias for "@"

在poi的doc上, 有hssfcellstyle有getDataFormatString方法, 估计就是直接给出"# ?/?"(单元格format), 但在我机子上的POI没有, 也许是我没有用最新的版本

最后, 补充点 excel 知识, 在excel上, 要在excel指定"7 1/4"这种数值格式为文本, 可以直接指定"7 1/4"为文本格式, 又或者在常规格式下, 输入"'7 1/4", 这样也是它将也会是文本格式, 在单元格左上角会有一个小小的三角图标
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值