我将我的字符串格式化为:20170814并希望通过as.Date函数转换为日期,但继续生成我' NA"。 这是我的功能:
a<-"20170814"
as.Date(a,"%y-%m/%d")
你能帮我个忙吗?
感谢
答案 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
。