16

我试图将一个数据框(动物园对象)作为一个整体复制 50 次,并将结果作为一个矩阵得到,但我尝试过的所有命令似乎都不成功。我可以很容易地编写一个函数来做到这一点,但我希望结果可以很容易地使用rep.

以以下为例

 x <- zoo(data.frame(A = c(1,2,3,4,5,6), B = c(7,8,9,10,11,12), C = c(13,14,15,16,17,18)), order.by = seq(as.Date("2012-01-01"), as.Date("2012-06-01"), by  = "month"))

 #> x
 #           A  B  C
 #2012-01-01 1  7 13
 #2012-02-01 2  8 14
 #2012-03-01 3  9 15
 #2012-04-01 4 10 16
 #2012-05-01 5 11 17
 #2012-06-01 6 12 18

让我们尝试复制x2 次。我正在寻找的最终结果是:

 #      [,1] [,2] [,3]
 # [1,]    1    7   13
 # [2,]    2    8   14
 # [3,]    3    9   15
 # [4,]    4   10   16
 # [5,]    5   11   17
 # [6,]    6   12   18
 # [7,]    1    7   13
 # [8,]    2    8   14
 # [9,]    3    9   15
 #[10,]    4   10   16
 #[11,]    5   11   17
 #[12,]    6   12   18

这是我迄今为止尝试过的,但这些都不起作用:

 matrix(rep(x,2), ncol = 3, byrow = T)

或者

 matrix(rep(x,2), ncol = 3, byrow = F)

或者

 matrix(rep(x, each = 2), ncol = 3)

有人可以帮忙吗?

谢谢,

4

6 回答 6

15
coredata(x)[rep(seq(nrow(x)),50),]
       A  B  C
  [1,] 1  7 13
  [2,] 2  8 14
  [3,] 3  9 15
  [4,] 4 10 16
  [5,] 5 11 17
  [6,] 6 12 18
...snip...
[295,] 1  7 13
[296,] 2  8 14
[297,] 3  9 15
[298,] 4 10 16
[299,] 5 11 17
[300,] 6 12 18
于 2013-08-28T13:12:46.900 回答
12
sapply(x, rep.int, times=3)
#      A  B  C
# [1,] 1  7 13
# [2,] 2  8 14
# [3,] 3  9 15
# [4,] 4 10 16
# [5,] 5 11 17
# [6,] 6 12 18
# [7,] 1  7 13
# [8,] 2  8 14
# [9,] 3  9 15
# [10,] 4 10 16
# [11,] 5 11 17
# [12,] 6 12 18
# [13,] 1  7 13
# [14,] 2  8 14
# [15,] 3  9 15
# [16,] 4 10 16
# [17,] 5 11 17
# [18,] 6 12 18
于 2013-08-28T13:11:22.070 回答
6

怎么样replicate

do.call(rbind, replicate(5, as.matrix(x), simplify=FALSE))

coredata()实际上,使用我已经忘记的更快(但仍然不如接受的答案快) 。

do.call(rbind, replicate(5, coredata(x), simplify = FALSE))
于 2013-08-28T13:10:33.503 回答
1

mapply() 函数呢?

mapply(rep, x, 3)
于 2021-05-30T12:45:21.813 回答
1

purrr风格

df <- iris[1:3,]
N <- 3
library(tidyverse)
reduce(seq_len(N -1), .init = df, ~bind_rows(.x, df))
#>   Sepal.Length Sepal.Width Petal.Length Petal.Width Species
#> 1          5.1         3.5          1.4         0.2  setosa
#> 2          4.9         3.0          1.4         0.2  setosa
#> 3          4.7         3.2          1.3         0.2  setosa
#> 4          5.1         3.5          1.4         0.2  setosa
#> 5          4.9         3.0          1.4         0.2  setosa
#> 6          4.7         3.2          1.3         0.2  setosa
#> 7          5.1         3.5          1.4         0.2  setosa
#> 8          4.9         3.0          1.4         0.2  setosa
#> 9          4.7         3.2          1.3         0.2  setosa

reprex 包于 2021-05-30 创建 (v2.0.0 )


类似的baseR风格

df <- iris[1:3,]
N <- 3

Reduce(function(.x, .y) rbind(.x, df), seq_len(N -1), init = df)
#>   Sepal.Length Sepal.Width Petal.Length Petal.Width Species
#> 1          5.1         3.5          1.4         0.2  setosa
#> 2          4.9         3.0          1.4         0.2  setosa
#> 3          4.7         3.2          1.3         0.2  setosa
#> 4          5.1         3.5          1.4         0.2  setosa
#> 5          4.9         3.0          1.4         0.2  setosa
#> 6          4.7         3.2          1.3         0.2  setosa
#> 7          5.1         3.5          1.4         0.2  setosa
#> 8          4.9         3.0          1.4         0.2  setosa
#> 9          4.7         3.2          1.3         0.2  setosa

reprex 包于 2021-05-30 创建 (v2.0.0 )

于 2021-05-30T12:53:36.057 回答
0

我们可以在包中使用bind_rows(将所有数据帧组合在一个列表中)dplyr,因此我们可以避免do.call()rbind()

library(dplyr)
bind_rows(replicate(2, x, simplify = FALSE))

输出:

       A     B     C
   <dbl> <dbl> <dbl>
 1     1     7    13
 2     2     8    14
 3     3     9    15
 4     4    10    16
 5     5    11    17
 6     6    12    18
 7     1     7    13
 8     2     8    14
 9     3     9    15
10     4    10    16
11     5    11    17
12     6    12    18
于 2021-05-30T13:24:52.030 回答