use*_*188 7 java java-8 java-time datetimeformatter
我们是否知道是否存在输出与 相同结果的等效格式字符串DateTimeFormatter.ISO_OFFSET_DATE_TIME?
IE
ZonedDateTime dateTime = ZonedDateTime.now();
System.out.println(dateTime.format(DateTimeFormatter.ofPattern(pattern)));
System.out.println(dateTime.format(DateTimeFormatter.ISO_OFFSET_DATE_TIME));
Run Code Online (Sandbox Code Playgroud)
会输出相同的
这对我有用:
ZonedDateTime dateTime = ZonedDateTime.now();
System.out.println(dateTime.format(DateTimeFormatter.ofPattern("yyyy-MM-dd'T'HH:mm:ss.SSSXXX")));
System.out.println(dateTime.format(DateTimeFormatter.ISO_OFFSET_DATE_TIME));
2018-10-03T07:24:14.772+03:00
2018-10-03T07:24:14.772+03:00
Run Code Online (Sandbox Code Playgroud)
虽然它不会总是产生相同的结果,因为 ISO_OFFSET_DATE_TIME 根据 nanos 值打印具有不同长度的秒部分,而 .SSS 已固定 lengh = 3
ZonedDateTime dateTime = ZonedDateTime.of(2001, 1, 1, 0, 0, 0, 1, ZoneId.systemDefault());
System.out.println(dateTime.format(DateTimeFormatter.ofPattern("yyyy-MM-dd'T'HH:mm:ss.SSSXXX")));
System.out.println(dateTime.format(DateTimeFormatter.ISO_OFFSET_DATE_TIME));
2001-01-01T00:00:00.000+02:00
2001-01-01T00:00:00.000000001+02:00
Run Code Online (Sandbox Code Playgroud)
应要求:是的,我们知道没有等效的DateTimeFormatter.ISO_OFFSET_DATE_TIME.
DateTimeFormatter.ISO_OFFSET_DATE_TIME如果它们为零,则省略秒和/或 nano 秒。如果 nanos 非零,“将根据需要输出尽可能多的数字。” 没有模式字母或模式字母的组合会给你相同的行为。
在内部深处DateTimeFormatter,ISO_OFFSET_DATE_TIME使用了ISO_LOCAL_TIME,而它又是这样定义的:
ISO_LOCAL_TIME = new DateTimeFormatterBuilder()
.appendValue(HOUR_OF_DAY, 2)
.appendLiteral(':')
.appendValue(MINUTE_OF_HOUR, 2)
.optionalStart()
.appendLiteral(':')
.appendValue(SECOND_OF_MINUTE, 2)
.optionalStart()
.appendFraction(NANO_OF_SECOND, 0, 9, true)
.toFormatter(ResolverStyle.STRICT, null);
Run Code Online (Sandbox Code Playgroud)
这是获得动态行为的方式:利用DateTimeFormatterBuilder其optionalStart和appendFraction方法。
顺便说一句,您不想完全复制 的行为ISO_OFFSET_DATE_TIME。您将需要使用内置格式化程序。
| 归档时间: |
|
| 查看次数: |
10013 次 |
| 最近记录: |