我的字符串格式为:20170814,并希望通过as.Date函数转换为日期,但继续生成我'NA'。这是我的函数:
a<-"20170814"
as.Date(a,"%y-%m/%d")
你能帮我一下吗谢谢
你想用
as.Date(a, "%Y%m%d")
# [1] "2017-08-14"
因为"%Y%m%d"
是您提供的字符格式的描述,不包括/
或-
。此外,当年份由4位而不是2位组成时,需要Y
。
格式是%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"
lubridate
的一个解决方案:
lubridate::ymd(a)
# [1] "2017-08-14"
class(lubridate::ymd(a))
# [1] "Date"