R Strptime年份和月份没有分隔符返回NA

Kyl*_*ndt 12 time r

我可能做了一些愚蠢而没有看到它的东西,但是:

> strptime("201101","%Y%m")
[1] NA
Run Code Online (Sandbox Code Playgroud)

从帮助strptime:

%Y年份与世纪
%m月份为十进制数字(01-12)

Dir*_*tel 15

只需粘贴您忽略的日期字段(例如"01"):

R> shortdate <- "201101"
R> as.Date(paste(shortdate, "01", sep=""), "%Y%m%d")
[1] "2011-01-01"
R> 
Run Code Online (Sandbox Code Playgroud)

我喜欢as.Date()的日期,并strptime()POSIXct对象,即日期和时间.

然后,您可以将解析的Date对象转换为POSIXlt对象以检索年和月:

R> mydt <- as.Date(paste(shortdate, "01", sep=""), "%Y%m%d")
R> myp <- as.POSIXlt(mydt)
R> c(myp$year, myp$mon)
[1] 111   0
R> 
Run Code Online (Sandbox Code Playgroud)

这是标准的POSIX行为,年份为"年 - 1900",月份为零索引.

七年后编辑:为了完整性,并且正如有人赞成这个,我的随时包中的函数可以帮助:

R> anytime::anydate("201101")    ## returns a Date
[1] "2011-01-01"
R> anytime::anytime("201101")    ## returns a Datetime
[1] "2011-01-01 CST"
R> 
Run Code Online (Sandbox Code Playgroud)

使用不同的解析器(来自Boost Date_time,它更慷慨并且会导致丢失的一天(或第二种情况下的日/小时/分钟/秒).