XSSF POI 是单元格日期

发布于 2024-11-19 14:04:08 字数 84 浏览 3 评论 0原文

有没有办法确定单元格是否是日期? 我知道 style.getDataFormatString() 但这对我没有帮助, 因为我无法确定格式化是否适用于日期。

Is there a way to determine if cell is a date?
I know about style.getDataFormatString() but that doesn't help me,
because I can't determine if is formating is for date or not.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

心舞飞扬 2024-11-26 14:04:08

如果您使用的是 XSSF UserModel,那么您需要 DateUtil.isCellDateFormatted(Cell) - 这将返回一个布尔值,告诉您单元格的格式字符串是否表示是否有数据。

如果您对低级 XML 内容不太了解,则需要 DateUtil.isADateFormat(int,String) 代替。样式 ID 来自单元格 xml。您必须从样式表中获取样式字符串,它是不同的包部分。有一些帮助程序可以加载它,但

您可能想看看 XSSFExcelExtractorDecorator 来自 Tika 作为执行后者的示例 - 它确实通过事件解析对单元格进行格式化。

If you're using the XSSF UserModel, then you want DateUtil.isCellDateFormatted(Cell) - this will return a boolean telling you if the format string for the cell represents a data or not.

If you're down at the low level XML stuff, you need DateUtil.isADateFormat(int,String) instead. The style ID comes from the cell xml. The style string you'll have to get out of the styles table, which is a different Package Part. There are helpers for loading that though

You probably want to look at XSSFExcelExtractorDecorator from Tika for an example of doing the latter - it does formatting of cells from an event parsing.

孤星 2024-11-26 14:04:08

cell.getCellTypeEnum() == CellType.NUMERIC && DateUtil.isCellDateFormatted(单元格)

cell.getCellTypeEnum() == CellType.NUMERIC && DateUtil.isCellDateFormatted(cell)

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文