通过as.Date函数将字符串转换为Date

时间:2018-03-05 23:15:03

标签: r as.date

我将我的字符串格式化为:20170814并希望通过as.Date函数转换为日期,但继续生成我' NA"。 这是我的功能:

a<-"20170814"
as.Date(a,"%y-%m/%d")
你能帮我个忙吗? 感谢

3 个答案:

答案 0 :(得分:2)

格式为%Y%m%d,且没有-

as.Date(a,"%Y%m%d")
#[1] "2017-08-14"

另一个选项是anytime,它可以解析大部分格式并将其转换为Date

anytime::anydate(a)
#[1] "2017-08-14"

class(anytime::anydate(a))
#[1] "Date"

答案 1 :(得分:2)

lubridate的一个解决方案:

lubridate::ymd(a)

# [1] "2017-08-14"

class(lubridate::ymd(a))

# [1] "Date"

答案 2 :(得分:1)

您想要使用

as.Date(a, "%Y%m%d")
# [1] "2017-08-14"

因为"%Y%m%d"是您提供的字符格式的描述,不包括/-。此外,当年份由4位而不是2位组成时,需要Y