我有一个模式为yyyy-M-d"
的SimpleDateFormat,以及以下场景:
String str = "02-03-04";
SimpleDateFormat f = new SimpleDateFormat("yyyy-M-d");
f.setLenient(false);
System.out.println(f.parse(str));
输出为Sat Mar 04 00:00:00 EST 2
我的目标是仅以2004-02-03的格式捕捉日期并忽略02-03-04。我认为模式中的yyyy需要4位数年份,但显然事实并非如此。任何人都可以解释为什么这不会抛出一个解析异常?我想要...
答案 0 :(得分:7)
好吧,我可以从the docs解释一下:
对于解析,如果模式字母的数量大于2,则无论数字位数如何,都按字面解释年份。所以使用模式“MM / dd / yyyy”,“01/11/12”解析到12月1日,12 A.D。
Joda Time可能更严格 - 而且它通常是一个更好的API,IMO ......
如果解析后年份小于1000,您总是可以抛出异常...
答案 1 :(得分:1)
使用 java.time ,具有该格式设置模式的输入将失败,就像您期望的那样。
LocalDate
.parse(
"02-03-04" ,
DateTimeFormatter.ofPattern ( "uuuu-M-d" )
)
…抛出java.time.format.DateTimeParseException
您正在使用的类现在已由JSR 310中定义的现代 java.time 类取代,并已内置到Java 8和更高版本中。
LocalDate
类表示没有日期,没有time zone或offset-from-UTC的仅日期值。
根据您的要求定义自定义格式设置模式。使用DateTimeFormatter
类。
DateTimeFormatter f = DateTimeFormatter.ofPattern ( "uuuu-M-d" );
尝试解析您的输入。
String input = "02-03-04";
LocalDate localDate = LocalDate.parse ( input , f );
我们遇到了DateTimeParseException
,在输入年份缺少的世纪中失败了。如您所料。
线程“ main”中的异常java.time.format.DateTimeParseException:无法在索引0处解析文本“ 02-03-04”
java.time框架已内置在Java 8及更高版本中。这些类取代了麻烦的旧legacy日期时间类,例如java.util.Date
,Calendar
和SimpleDateFormat
。
要了解更多信息,请参见Oracle Tutorial。并在Stack Overflow中搜索许多示例和说明。规格为JSR 310。
目前位于Joda-Time的maintenance mode项目建议迁移到java.time类。
您可以直接与数据库交换 java.time 对象。使用符合JDBC driver或更高版本的JDBC 4.2。不需要字符串,不需要java.sql.*
类。
在哪里获取java.time类?
ThreeTen-Extra项目使用其他类扩展了java.time。该项目为将来可能在java.time中添加内容提供了一个试验场。您可能会在这里找到一些有用的类,例如Interval
,YearWeek
,YearQuarter
和more。