我正在使用Joda解析包含日期/時(shí)間的第三方日志文件。日期/時(shí)間采用兩種不同格式之一,具體取決于我要分析的日志文件的使用期限。目前,我有這樣的代碼:try { return DateTimeFormat.forPattern("yyyy/MM/dd HH:mm:ss").parseDateTime(datePart);} catch (IllegalArgumentException e) { return DateTimeFormat.forPattern("E, MMM dd, yyyy HH:mm").parseDateTime(datePart);}此方法有效,但違反了有效Java 2nd Edition中Joshua Bloch的建議(條款57:僅在特殊情況下使用例外)。由于日志文件中錯(cuò)誤的日期/時(shí)間,這也使得很難確定是否發(fā)生IllegalArgumentException。您能提出一種不會(huì)濫用異常的更好的方法嗎?
3 回答

呼喚遠(yuǎn)方
TA貢獻(xiàn)1856條經(jīng)驗(yàn) 獲得超11個(gè)贊
Joda-Time通過允許指定多個(gè)解析器來支持此功能-DateTimeFormatterBuilder#append
只需使用構(gòu)建器創(chuàng)建兩個(gè)格式化程序,然后分別調(diào)用toParser()它們。然后使用構(gòu)建器將它們結(jié)合使用append。

慕神8447489
TA貢獻(xiàn)1780條經(jīng)驗(yàn) 獲得超1個(gè)贊
不幸的是,我不相信Joda Time具有任何這樣的功能。擁有“ tryParseDateTime”方法會(huì)很好,但是它不存在。
我建議您將此行為隔離到自己的類中(一個(gè)接受一系列模式并依次嘗試的模式),以便僅將丑陋之處放在一個(gè)地方。如果這導(dǎo)致性能問題,您可能想要嘗試使用一些啟發(fā)式方法來猜測首先嘗試哪種格式。例如,如果您的字符串以數(shù)字開頭,則可能是第一個(gè)模式。
請注意,DateTimeFormatter
Joda Time中的s通常是不可變的-每次要解析一行時(shí)都不應(yīng)創(chuàng)建一個(gè)新值。一次創(chuàng)建它們并重復(fù)使用它們。
添加回答
舉報(bào)
0/150
提交
取消