SimpleDateFormat parse (string str) не создает исключение, когда str = 2011/12/12aaaaaaaaa?
вот пример:
public MyDate() throws ParseException {
SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/d");
sdf.setLenient(false);
String t1 = "2011/12/12aaa";
System.out.println(sdf.parse(t1));
}
2011/12 / 12aaa не является допустимой строкой даты. Однако функция печатает "Пн дек 12 00:00: 00 PST 2011" и ParseException не выбрасывается.
может ли кто-нибудь сказать мне, как позволить SimpleDateFormat рассматривать "2011/12/12aaa" как недопустимую строку даты и выдавать исключение?
6 ответов
JavaDoc на parse(...)
указано следующее:
синтаксический анализ не обязательно использует все символы до конца строки
кажется, что вы не можете сделать SimpleDateFormat
бросать исключение, но вы можете сделать следующее:
SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/d");
sdf.setLenient(false);
ParsePosition p = new ParsePosition( 0 );
String t1 = "2011/12/12aaa";
System.out.println(sdf.parse(t1,p));
if(p.getIndex() < t1.length()) {
throw new ParseException( t1, p.getIndex() );
}
В основном, вы проверяете, потреблял ли синтаксический анализ всю строку, и если нет, у вас есть недопустимый ввод.
чтобы проверить, является ли дата действительной Следующий метод возвращает, если дата является допустимой, в противном случае он вернет false.
public boolean isValidDate(String date) {
SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/d");
Date testDate = null;
try {
testDate = sdf.parse(date);
}
catch (ParseException e) {
return false;
}
if (!sdf.format(testDate).equals(date)) {
return false;
}
return true;
}
посмотрите на следующий класс, который может проверить, является ли дата действительной или нет
** Пример**
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
public class DateValidCheck {
public static void main(String[] args) {
if(new DateValidCheck().isValidDate("2011/12/12aaa")){
System.out.println("...date is valid");
}else{
System.out.println("...date is invalid...");
}
}
public boolean isValidDate(String date) {
SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/d");
Date testDate = null;
try {
testDate = sdf.parse(date);
}
catch (ParseException e) {
return false;
}
if (!sdf.format(testDate).equals(date)) {
return false;
}
return true;
}
}
после того, как он успешно разобрал всю строку шаблона SimpleDateFormat
останавливает оценку данных, которые были даны для анализа.
может использоваться Java 8 LocalDate:
public static boolean isDate(String date) {
try {
LocalDate.parse(date, DateTimeFormatter.ofPattern("yyyy/MM/dd"));
return true;
} catch (DateTimeParseException e) {
return false;
}
}
если входной аргумент является "2011/12/12aaaaaaaaa"
вывод false
;
если входной аргумент является "2011/12/12"
вывод true
взгляните на документацию метода, которая говорит:ParseException if the beginning of the specified string cannot be parsed
.
исходный код метода с javadoc:
/**
* Parses text from the beginning of the given string to produce a date.
* The method may not use the entire text of the given string.
* <p>
* See the {@link #parse(String, ParsePosition)} method for more information
* on date parsing.
*
* @param source A <code>String</code> whose beginning should be parsed.
* @return A <code>Date</code> parsed from the string.
* @exception ParseException if the beginning of the specified string
* cannot be parsed.
*/
public Date parse(String source) throws ParseException
{
ParsePosition pos = new ParsePosition(0);
Date result = parse(source, pos);
if (pos.index == 0)
throw new ParseException("Unparseable date: \"" + source + "\"" ,
pos.errorIndex);
return result;
}
можно использовать ParsePosition
или sdf.setLenient(false)
функции
документы: http://docs.oracle.com/javase/7/docs/api/java/text/ParsePosition.html http://docs.oracle.com/javase/7/docs/api/java/text/DateFormat.html#setLenient(boolean)