POI设置日期类型时间约束createDateConstraint不生效了

背景

在使用 POI 导出 excel 时间类型加入时间约束时,发生了使用 Excel 打开无法正确使用时间约束的问题,但是在 永中Office 打开可以使用

关键词

helper.createDateConstraint,POI设置时间约束

设置时间约束的代码如下

该代码是有问题的,正确的代码在文章末尾

String dateFormat = "yyyy/MM/dd";
            String start = "1900,01,01";
            String end = "2399,12,30";
            constraint = helper.createDateConstraint(DataValidationConstraint.OperatorType.BETWEEN, start, end, dateFormat);

解决思路

1、排查使用 POI 设置的时间约束与在 Excel 中创建的时间约束有什么不通

2、修改格式化日期格式测试是否可以生效

3、修改日期范围大小测试是否生效

4、查看 createDateConstraint 方法接收的参数各是什么意思,需要什么格式

5、查阅网上资料

问题所在

经过上面几步的排查,初步确定应该是设置的日期格式问题,但是不懂如何正确设置,所以交给了优秀的互联网,google 一下,此时发现一篇文章写的不错(http://t.csdn.cn/OyWGv),解决了我的问题,然后继续查阅引用链接(https://www.demo2s.com/java/apache-poi-datavalidationhelper-createdateconstraint-int-operatortype.html),最终找到了答案,解决问题

alt

最终代码

 String dateFormat = "yyyy/MM/dd";
            String start = "Date(1900,01,01)";
            String end = "Date(2399,12,30)";
            constraint = helper.createDateConstraint(DataValidationConstraint.OperatorType.BETWEEN, start, end, dateFormat);

即将设置的日期加入 Date 的包装即可

参考链接

1、https://www.demo2s.com/java/apache-poi-datavalidationhelper-createdateconstraint-int-operatortype.html

2、http://t.csdn.cn/OyWGv

本文由 mdnice 多平台发布

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值