将日期格式化为格式“%Y-%m”时出现问题

时间:2013-05-06 15:29:26

标签: r

我希望R将一列视为日期。它在导入过程中被视为因子,但是,当我尝试使用'as.Date'和'format'进行格式化时,我只会获得NAs。我不确定我哪里出错了。

> d = read.table("ByMonth.Year_54428.txt", header=T, sep=",")  
> str(d)  
'data.frame':   607 obs. of  2 variables:
 $ V1  : Factor w/ 607 levels "1950-12","1951-01",..: 1 2 3 4 5 6 7 8 9 10 ...
 $ Rain: int  100 56000 29293 37740 19649 41436 58067 51082 49629 62680 ...
> 
> 
> Date.form1 <- as.Date(d$V1, "%Y-%m")
> str(Date.form1)
 Date[1:607], format: NA NA NA NA NA NA NA NA NA NA NA NA NA NA ...
> 
> Date.form2 = as.Date(as.character(d$V1), format="%Y-%m")
> str(Date.form2)
 Date[1:607], format: NA NA NA NA NA NA NA NA NA NA NA NA NA NA ...

1 个答案:

答案 0 :(得分:14)

一年零一个月没有约会。你也需要一天。

d <- data.frame(V1=c("1950-12","1951-01"))
as.Date(paste(d$V1,1,sep="-"),"%Y-%m-%d")
# [1] "1950-12-01" "1951-01-01"

您还可以在动物园包中使用yearmon类。

library(zoo)
as.yearmon(d$V1)
# [1] "Dec 1950" "Jan 1951"