تنسيق التاريخ جافا التي تسمح - / أو. كما فصل في التاريخ
-
22-07-2019 - |
سؤال
ما اجمل طريقة لتحليل التاريخ الذي يمكن أن يكون في واحدة من الصيغ التالية
"dd-MM-yyyy HH:mm"
"dd/MM/yyyy HH:mm"
"dd.MM.yyyy HH:mm"
ودون خلق 3 SimpleDateFormats وتحليل ضد كل واحد.
والشكر
المحلول
وانها ربما أسهل إلى "قرص" سلسلة المصدر إلى شكل قانوني:
if (text.length() == 16)
{
if ((text.charAt(2) == '/' && text.charAt(5) == '/') ||
(text.charAt(2) == '.' && text.charAt(5) == '.'))
{
text = text.substring(0, 2) + "-" + text.substring(3, 5)
+ "-" + text.substring(6);
}
}
وبعد ذلك استخدام سلسلة التنسيق باستخدام "-"
.لاحظ أن هذا هو محددة للغاية، لتحل محل فقط <م> بالضبط م> الأحرف كنت مهتما، لتجنب التأثيرات الجانبية غير المرغوبة.
نصائح أخرى
هل يمكن تشغيل اثنين استبدال العمليات لأول مرة، بحيث يمكنك تقليل جميع صيغ ثلاثة إلى واحد؟
يمكنك استخدام <لأ href = "http://commons.apache.org/lang//api/org/apache/commons/lang/time/DateUtils.html#parseDate(java.lang.String،٪20java .lang.String []) "يختلط =" نوفولو noreferrer "> أباتشي العموم لانج DateUtils.parseDate
import java.text.ParseException;
import org.apache.commons.lang.time.DateUtils;
public class Test {
public static void main(String[] args) throws ParseException {
String[] values = new String[]{"31-12-2009 12:00", "31/12/2009 12:00", "31.12.2009 12:00"};
String[] parsePatterns = new String[]{"dd-MM-yyyy HH:mm", "dd/MM/yyyy HH:mm", "dd.MM.yyyy HH:mm"};
for (String value : values) {
System.out.println(DateUtils.parseDate(value, parsePatterns));
}
}
}
حسنا، داخليا يخلق SimpleDateFormats، ولكن ما الخطأ في ذلك؟
وماذا عن التعابير المنطقية:
"\\d\\d[./-]\\d\\d[./-]\\d\\d\\d\\d \\d\\d:\\d\\d"
في كود هذا يعني شيئا من هذا القبيل:
Pattern pattern =
Pattern.compile("(\\d\\d)([./-])(\\d\\d)([./-])(\\d\\d\\d\\d) (\\d\\d):(\\d\\d)");
Matcher matcher =
pattern.matcher("31-07-1983 15:30");
if (matcher.find() && matcher.group(2).equals(matcher.group(4))) {
int day = Integer.parseInt(matcher.group(1));
int month = Integer.parseInt(matcher.group(3));
int year = Integer.parseInt(matcher.group(5));
int hour = Integer.parseInt(matcher.group(6));
int minute = Integer.parseInt(matcher.group(7));
}
وفعل ذلك بنفسك مع تعبير عادي:
public class SpecialDateFormat
{
private final static Pattern PATTERN = Pattern.compile("(\\d{2})[\\.\\/\\-](\\d{2})[\\.\\/\\-](\\d{4}) (\\d{2}):(\\d{2})");
public static Date parse(String text) throws ParseException {
Matcher m = PATTERN.matcher(text);
if (m.matches()) {
int dd = Integer.parseInt(m.group(1));
int mm = Integer.parseInt(m.group(2));
int yy = Integer.parseInt(m.group(3));
int hh = Integer.parseInt(m.group(4));
int mi = Integer.parseInt(m.group(5));
// NOTE: Checking if values are in valid ranges omitted
Calendar cal = Calendar.getInstance();
cal.set(yy, mm - 1, dd, hh, mi, 0);
return cal.getTime();
}
else {
throw new ParseException("Unparseable date: " + text, 0);
}
}
}
ملحوظة إلا أن هذا لا تسمح خلط فواصل مختلفة، على سبيل المثال "17-09 / 2009 00:00" سيسمح.
وParseExact يمكن أن تتخذ مجموعة من الأشكال. لا يزال لديك لتحديد جميع الأشكال، لكنها عملية واحدة.