Разбор SimpleDateFormat (строка 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;
}
}
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
После того, как он успешно проанализировал всю строку шаблона SimpleDateFormat
перестает оценивать данные, которые были даны для разбора.
Вы можете использовать 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
Посмотрите на документацию метода, которая гласит: 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;
}