我必须在数据库中添加一个格式为“ MM-YY”的字符串,该字符串表示信用卡的到期日期,其中MM是月份,而YY是年份的最后两位数字,如何检查字符串在Java中是这种特定格式吗?
答案 0 :(得分:0)
使用正则表达式:
String myString = "12-99";
if( myString.matches("((0[1-9])|(1[0-2]))-\\d{2}") ){
System.out.println("Correct format");
}
else{
System.out.println("Incorrect format");
}
答案 1 :(得分:0)
尝试在正则表达式下使用
String str = "10-18";
if (str.matches("([0-9]{2})-([0-9]{2})"))
System.out.println("Correct");
else
System.out.println("Incorrect");
答案 2 :(得分:0)
java.time.YearMonth
解析为YearMonth
。捕获异常。
String input = "99-18" ; // Valid: "01-18" Invalid: "99-18"
DateTimeFormatter f = DateTimeFormatter.ofPattern( "MM-uu" ) ;
YearMonth ym = null ;
try {
ym = YearMonth.parse( input , f ) ;
} catch ( DateTimeParseException e ) {
System.out.println( "Invalid input: " + input ) ;
}
System.out.println( "ym.toString(): " + ym ) ;
请参阅此code run live on IdeOne.com。
无效输入:99-18
ym.toString():空
java.time框架已内置在Java 8及更高版本中。这些类取代了麻烦的旧legacy日期时间类,例如java.util.Date
,Calendar
和SimpleDateFormat
。
目前位于Joda-Time的maintenance mode项目建议迁移到java.time类。
要了解更多信息,请参见Oracle Tutorial。并在Stack Overflow中搜索许多示例和说明。规格为JSR 310。
您可以直接与数据库交换 java.time 对象。使用符合JDBC driver或更高版本的JDBC 4.2。不需要字符串,不需要java.sql.*
类。
在哪里获取java.time类?
ThreeTen-Extra项目使用其他类扩展了java.time。该项目为将来可能在java.time中添加内容提供了一个试验场。您可能会在这里找到一些有用的类,例如Interval
,YearWeek
,YearQuarter
和more。