ISO文字列の日付のように見えるかなりすべてのためのマッチング究極のパターンです!
"[yyyyMMdd][yyyy-MM-dd][yyyy-DDD]['T'[HHmmss][HHmm][HH:mm:ss][HH:mm][.SSSSSSSSS][.SSSSSS][.SSS][.SS][.S]][OOOO][O][z][XXXXX][XXXX]['['VV']']"
それは、コメント内の2つを除き、テストの次のリストのために動作しますが、私はまだ理由がわからない...
ZonedDateTime dt = DateTimeUtils.parse("2016-10-27T16:36:08.993+02:00:00[Europe/Paris]");
dt = DateTimeUtils.parse("2016-10-27T16:36:08.993+02:00[Europe/Paris]");
dt = DateTimeUtils.parse("2016-10-27T16:36:08.993+020000[Europe/Paris]");
dt = DateTimeUtils.parse("2016-10-27T16:36:08.993+0200[Europe/Paris]");
dt = DateTimeUtils.parse("2016-10-27T16:36:08.993+0000[Europe/Paris]");
dt = DateTimeUtils.parse("2016-10-27T16:36:08.993Z[Europe/Paris]");
dt = DateTimeUtils.parse("2016-10-27T16:36:08.993GMT+1[Europe/Paris]");
dt = DateTimeUtils.parse("2016-10-27T16:36:08.993UTC[Europe/Paris]");
dt = DateTimeUtils.parse("2016-10-27T16:36:08.993PST[Europe/Paris]");
dt = DateTimeUtils.parse("2016-10-27T16:36:08.993[Europe/Paris]");
dt = DateTimeUtils.parse("2016-10-27T16:36:08+02:00[Europe/Paris]");
dt = DateTimeUtils.parse("2016-10-27T16:36:08+020000[Europe/Paris]");
dt = DateTimeUtils.parse("2016-10-27T16:36:08+0200[Europe/Paris]");
dt = DateTimeUtils.parse("2016-10-27T16:36:08+0000[Europe/Paris]");
dt = DateTimeUtils.parse("2016-10-27T16:36:08Z[Europe/Paris]");
dt = DateTimeUtils.parse("2016-10-27T16:36:08GMT+1[Europe/Paris]");
dt = DateTimeUtils.parse("2016-10-27T16:36:08UTC[Europe/Paris]");
dt = DateTimeUtils.parse("2016-10-27T16:36:08PST[Europe/Paris]");
dt = DateTimeUtils.parse("2016-10-27T16:36:08[Europe/Paris]");
dt = DateTimeUtils.parse("2016-10-27T16:36:08.993+02:00:00");
dt = DateTimeUtils.parse("2016-10-27T16:36:08.993+02:00");
dt = DateTimeUtils.parse("2016-10-27T16:36:08.993+020000");
dt = DateTimeUtils.parse("2016-10-27T16:36:08.993+0200");
dt = DateTimeUtils.parse("2016-10-27T16:36:08.993+0000");
dt = DateTimeUtils.parse("2016-10-27T16:36:08.993Z");
//dt = DateTimeUtils.parse("2016-10-27T16:36:08.993GMT+1");
dt = DateTimeUtils.parse("2016-10-27T16:36:08.993UTC");
dt = DateTimeUtils.parse("2016-10-27T16:36:08.993PST");
dt = DateTimeUtils.parse("2016-10-27T16:36:08.993");
dt = DateTimeUtils.parse("2016-10-27T16:36:08.000993");
dt = DateTimeUtils.parse("2016-10-27T16:36:08.000000993");
dt = DateTimeUtils.parse("2016-10-27T16:36:08+02:00:00");
dt = DateTimeUtils.parse("2016-10-27T16:36:08+02:00");
dt = DateTimeUtils.parse("2016-10-27T16:36:08+020000");
dt = DateTimeUtils.parse("2016-10-27T16:36:08+0200");
dt = DateTimeUtils.parse("2016-10-27T16:36:08+0000");
dt = DateTimeUtils.parse("2016-10-27T16:36:08Z");
//dt = DateTimeUtils.parse("2016-10-27T16:36:08GMT+1");
dt = DateTimeUtils.parse("2016-10-27T16:36:08UTC");
dt = DateTimeUtils.parse("2016-10-27T16:36:08PST");
dt = DateTimeUtils.parse("2016-10-27T16:36:08");
dt = DateTimeUtils.parse("2016-100T16:36:08Z");
dt = DateTimeUtils.parse("2016-100T16:36.1Z");
dt = DateTimeUtils.parse("2016-10-27");
dt = DateTimeUtils.parse("20161223T163608");
dt = DateTimeUtils.parse("20161223T1636");
そしてparseメソッド自体:
public static ZonedDateTime parse(CharSequence text) {
TemporalAccessor temporalAccessor = LOOSE_ISO_DATE_TIME_ZONE_PARSER.parseBest(text, ZonedDateTime::from, LocalDateTime::from, LocalDate::from);
if (temporalAccessor instanceof ZonedDateTime) {
return ((ZonedDateTime) temporalAccessor);
}
if (temporalAccessor instanceof LocalDateTime) {
return ((LocalDateTime) temporalAccessor).atZone(ZoneId.systemDefault());
}
return ((LocalDate) temporalAccessor).atStartOfDay(ZoneId.systemDefault());
}
オプションであると考えるコロンは、ゾーンオフセット部分の固定部分です。パターン文字X(コロンなし)またはXXX(コロン付き)の間でのみ選択できます。つまり、ゾーン全体のオフセットは、内部のコロンだけでなくオプションです。 –
私は同意する、それは動作するはずです。しかし、私は[X]を使うとコロンなしのオフセットを期待しています。[XXX]を使うと、コロンでオフセットします。私は両方を一緒に使うことはできません。 –
Javadocによると:記号Xを用いた例題は次の通りです:Z; -08; -0830; -08:30; -083015; -08:30:15; –