在保留课程日期的同时将日期格式化为月-年

TAR*_*man 6 r date

我觉得有一种非常简单的方法可以做到这一点,但我并不容易找到它......

我正在使用 R 从数据集中提取数据,然后他们通过许多不同的特征对其进行总结。其中之一是安排/发生事件的月份。我们在数据库中有事件的确切日期,如下所示:

person_id    date_visit
1            2012-05-03
2            2012-08-13
3            2012-12-12
...
Run Code Online (Sandbox Code Playgroud)

我想使用该table()函数来生成一个如下所示的汇总表:

Month    Freq
Jan 12   1
Feb 12   2
Mar 12   1
Apr 12   3
...
Run Code Online (Sandbox Code Playgroud)

我的问题是这个。我已经读入数据并用于as.Date()将字符串转换为日期。我可以format.Date()用来获取格式为 Jan 12、Mar 12 等的日期。但是当你使用 时format.Date(),你最终会再次得到字符串。这意味着当你table()向他们申请时,他们会按字母顺序出现(我目前的日期是 8 月 12 日、7 月 12 日、6 月 12 日、3 月 12 日等等)。

我知道在 SAS 中,您可以使用格式来更改日期的外观,同时将其保留为日期(因此您仍然可以对其进行日期运算符)。使用 R 可以做同样的事情吗?

我的计划是通过多个步骤构建一个漂亮的数据框,然后(在确保所有日期都转换为字符串之后,出于兼容性原因)使用xtable()来制作一个漂亮的 LaTeX 输出。

这是我目前的代码。

load("temp.RData")
ds$date_visit <- as.Date(ds$date_visit,format="%Y-%m-%d")
table(format.Date(safebeat_recruiting$date_baseline,format="%b %Y"))
Run Code Online (Sandbox Code Playgroud)

ETA:如果可以的话,我更愿意只在 Base R 中进行,但如果必须的话,我总是可以使用额外的包。

GSe*_*See 5

您可以使用包中的yearmonzoo

require("zoo")
ds <- data.frame(person_id=1:3, date_visit=c("2012-05-03", "2012-08-13", "2012-12-12"))
ds$date_visit <- as.yearmon(ds$date_visit)
ds
  person_id date_visit
1         1   May 2012
2         2   Aug 2012
3         3   Dec 2012
Run Code Online (Sandbox Code Playgroud)


42-*_*42- 1

month.abb是 R 中的常量向量,可用于对names表中字符串 的前三个字母进行排序。

ds <- data.frame(person_id=1:3, date_visit=as.Date(c("2012-05-03", "2012-08-13", "2012-12-12")))
table(format( ds$date_visit, format="%b %Y"))
tbl <- table(format( ds$date_visit, format="%b %Y"))
tbl[order(  match(substr(names(tbl), 1,3), month.abb) )]

May 2012 Aug 2012 Dec 2012 
       1        1        1 
Run Code Online (Sandbox Code Playgroud)

再过几年,您会看到“五月”全部在一起,因此需要这样做:

 tbl[order( substr(names(tbl), 5,8),  match(substr(names(tbl), 1,3), month.abb) )]
Run Code Online (Sandbox Code Playgroud)