首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Apply + lubridate返回数字

Apply + lubridate返回数字
EN

Stack Overflow用户
提问于 2015-05-30 15:24:52
回答 1查看 755关注 0票数 4

我有一个像这样的数据集

代码语言:javascript
复制
birds[,1:3]
Source: local data frame [15 x 3]

   year month day
1  2015     5  13
2  2015     5  14
3  2015     5  15
4  2015     5  16
5  2015     5  17
6  2014     5  28
7  2014     5  29
8  2014     5  30
9  2014     5  31
10 2014     6   1
11 2013     5   8
12 2013     5   9
13 2013     5  10
14 2013     5  11
15 2013     5  12

我想要做的是将这些列合并成一个“日期”列,这样我就可以将它们粘贴在一起,并将它们传递给lubridate。

这样做是可行的:

代码语言:javascript
复制
ymd(paste(birds[1,1], birds[1,2], birds[1,3], sep="-"))
[1] "2015-05-13 UTC"

但是,当我尝试使用apply对每一行执行此操作时,我会得到以下内容:

代码语言:javascript
复制
apply(birds[,c("year","month","day")], 1, 
function(x) ymd(paste(x[1], x[2], x[3], sep="-")))
 [1] 1431475200 1431561600 1431648000 1431734400 1431820800 1401235200 1401321600 1401408000 1401494400
 [10] 1401580800 1367971200 1368057600 1368144000 1368230400 1368316800

为什么会发生这种事,我该如何解决呢?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-05-30 15:26:31

我们不需要applyMARGIN=1。相反,我们可以通过paste通过with(birds, paste(year, month, day, sep="-"))对列进行包装,并使用as.Date将其转换为“Date”类。ymd的输出是POSIXct类,在apply中,它将被强制为“数值”形式。

代码语言:javascript
复制
library(lubridate)
library(dplyr)
mutate(birds, date=ymd(paste(year, month, day)))

或者我们可以从tidyr中使用tidyr,然后转换成POSIXct类。

代码语言:javascript
复制
library(tidyr)
unite(birds, date, year:day, sep="-") %>% 
           mutate(date=ymd(date))

或者使用来自do.callbase Rymd

代码语言:javascript
复制
birds$date <- ymd(do.call(paste, birds))

或者您可以使用来自base Rbase R

代码语言:javascript
复制
as.Date(do.call(paste, c(birds,sep="-")))

要修复您使用apply获得的输出

代码语言:javascript
复制
res <- apply(birds[,c("year","month","day")], 1, 
      function(x) ymd(paste(x[1], x[2], x[3], sep="-")))
unname(as.POSIXct(res, origin='1970-01-01',tz='UTC'))
#[1] "2015-05-13 UTC" "2015-05-14 UTC" "2015-05-15 UTC" "2015-05-16 UTC"
#[5] "2015-05-17 UTC" "2014-05-28 UTC" "2014-05-29 UTC" "2014-05-30 UTC"
#[9] "2014-05-31 UTC" "2014-06-01 UTC" "2013-05-08 UTC" "2013-05-09 UTC"
#[13] "2013-05-10 UTC" "2013-05-11 UTC" "2013-05-12 UTC"

数据

代码语言:javascript
复制
birds <- structure(list(year = c(2015L, 2015L, 2015L, 2015L, 2015L, 
2014L, 
2014L, 2014L, 2014L, 2014L, 2013L, 2013L, 2013L, 2013L, 2013L
), month = c(5L, 5L, 5L, 5L, 5L, 5L, 5L, 5L, 5L, 6L, 5L, 5L, 
5L, 5L, 5L), day = c(13L, 14L, 15L, 16L, 17L, 28L, 29L, 30L, 
31L, 1L, 8L, 9L, 10L, 11L, 12L)), .Names = c("year", "month", 
"day"), class = "data.frame", row.names = c("1", "2", "3", "4", 
"5", "6", "7", "8", "9", "10", "11", "12", "13", "14", "15"))
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30547896

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档