在 Kotlin 中将日期字符串转换为所需的格式

问题描述

我想将日期转换为所需的格式。我知道首先我需要转换为日期然后需要格式化该日期。我的问题是以简单的形式做的任何最简单的方法。对性能有影响吗?因为我在列表中列出了所有这些日期。

例如

fun main(vararg args: String) {
    val dateString = "2021-05-12T12:12:12.121Z"
    val convertedDate = convertDate(dateString)
    print(
            convertedDate?.let {
                formatDate(it)
            }
    )
}

fun formatDate(date: Date): String {
    return SimpleDateFormat("MMM dd,YYYY").format(date)
}

fun convertDate(dateString: String): Date? {
    return SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSS'Z'").parse(dateString)
}

输出

May 12,2021

解决方法

标准日期时间类没有任何属性来保存格式信息。即使某些库或自定义类承诺这样做,它也违反了 Single Responsibility Principle。 Date-Time 对象应该存储有关日期、时间、时区等的信息,与格式无关。以所需格式表示日期时间对象的唯一方法是使用日期时间解析/格式化类型将其格式化为 String

  • 对于现代日期时间 API:java.time.format.DateTimeFormatter
  • 对于旧的 Date-Time API:java.text.SimpleDateFormat

请注意,java.util 日期时间 API 及其格式 API SimpleDateFormat 已过时且容易出错。建议完全停止使用它们并切换到 modern Date-Time API*,它于 2014 年 3 月作为 Java SE 8 标准库的一部分发布。

除此之外,您的代码还有很多问题:

  1. 使用 Y(周年)而不是 y(年)。查看 documentation 以了解更多信息。
  2. 不将 LocaleSimpleDateFormat 一起使用。查看 Never use SimpleDateFormat or DateTimeFormatter without a Locale 以了解更多信息。
  3. Z 括在单引号中意味着它只是一个字符文字,除了表示字母 Z 之外没有任何意义。模式 yyyy-MM-dd'T'HH:mm:ss.SSS'Z' 应该是 yyyy-MM-dd'T'HH:mm:ss.SSSXXX

使用 java.time(现代日期时间 API)的解决方案:

import java.time.OffsetDateTime;
import java.time.format.DateTimeFormatter;
import java.util.Locale;

public class Main {
    public static void main(String[] args) {
        var dateString = "2021-05-12T12:12:12.121Z";
        var odt = OffsetDateTime.parse(dateString);
        var dtf = DateTimeFormatter.ofPattern("MMM dd,uuuu",Locale.ENGLISH);
        System.out.println(dtf.format(odt));
    }
}

输出:

May 12,2021

ONLINE DEMO

在这里,您可以使用 y 代替 u,而是使用 I prefer u to y

Trail: Date Time 了解有关现代 Date-Time API 的更多信息。


* 出于任何原因,如果您必须坚持使用 Java 6 或 Java 7,您可以使用 ThreeTen-Backport,它将大部分 java.time 功能向后移植到 Java 6 & 7. 如果您正在为 Android 项目工作并且您的 Android API 级别仍然不符合 Java-8,请检查 Java 8+ APIs available through desugaringHow to use ThreeTenABP in Android Project