微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何将字符串更改为日期格式?

如何解决如何将字符串更改为日期格式?

这可能是某个地方的副本,但是我有一个简单的df:

df1_schema = StructType([StructField("Date",StringType(),True) ])
df_data = [('1-Jun-20',)]
rdd = sc.parallelize(df_data)
df1 = sqlContext.createDataFrame(df_data,df1_schema)
#df1 = df1.withColumn("Date",to_date("Date",'yyyy-MM-dd'))
df1.show()

+--------+
|    Date|
+--------+
|1-Jun-20|
+--------+

我试图更改为日期格式,但它只是给我一个空值。 这是我尝试过的:

df1= df1.withColumn("Date2",F.to_date(col('Date'),"dd-MM-yyyy"))
+----------+-----+
|      Date|Date2|
+----------+-----+
|1-Jun-20  | null|
+----------+-----+

对此有任何解决方案吗?。谢谢

解决方法

您的Date的正确格式为"d-MMM-yy"

df1.withColumn("Date2",F.to_date(col('Date'),"d-MMM-yy")).show()
+--------+----------+
|    Date|     Date2|
+--------+----------+
|1-Jun-20|2020-06-01|
+--------+----------+

这也适用于01-Jun-2010-Jun-20

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。