【问题标题】:R - Merge data "list" into one data.frameR - 将数据“列表”合并到一个 data.frame
【发布时间】:2012-02-13 18:44:27
【问题描述】:

当我使用列表功能时:

el_nino_1974_2000_all <- list()
for (k in seq_along(el_nino_start_month)){
     el_nino_1974_2000_all[[k]] = window(Nino3.4_Flow_1974_2000_zoo,
                                         start = (as.Date(el_nino_1974_2000[k,]$el_nino_start_mont)),
                                         end = (as.Date(el_nino_1974_2000[k,]$el_nino_finish_month)))
}

A 给出了一系列从i = 1 开始的独立数据子集。但是,我想将所有子集以动物园格式或数据帧格式合并到一帧数据中。

这是el_nino_1974_2000_all的结构。

    > str(el_nino_1974_2000_all)
List of 7
 $ :‘zoo’ series from 1976-08-15 to 1977-01-15
  Data: num [1:6, 1:2] 0.519 0.874 0.886 0.823 0.734 ...
  ..- attr(*, "dimnames")=List of 2
  .. ..$ : NULL
  .. ..$ : chr [1:2] "Nino3.4_degree_1974_2000" "Houlgrave_flow_1974_2000"
  Index:  Date[1:6], format: "1976-08-15" "1976-09-15" ...
 $ :‘zoo’ series from 1982-05-15 to 1983-06-15
  Data: num [1:14, 1:2] 0.961 1.388 0.959 1.171 1.564 ...
  ..- attr(*, "dimnames")=List of 2
  .. ..$ : NULL
  .. ..$ : chr [1:2] "Nino3.4_degree_1974_2000" "Houlgrave_flow_1974_2000"
  Index:  Date[1:14], format: "1982-05-15" "1982-06-15" ...
 $ :‘zoo’ series from 1986-09-15 to 1988-01-15
  Data: num [1:17, 1:2] 0.974 1.089 1.322 1.273 1.313 ...
  ..- attr(*, "dimnames")=List of 2
  .. ..$ : NULL
  .. ..$ : chr [1:2] "Nino3.4_degree_1974_2000" "Houlgrave_flow_1974_2000"
  Index:  Date[1:17], format: "1986-09-15" "1986-10-15" ...
 $ :‘zoo’ series from 1991-05-15 to 1992-07-15
  Data: num [1:15, 1:2] 0.68 1 0.923 0.773 0.68 ...
  ..- attr(*, "dimnames")=List of 2
  .. ..$ : NULL
  .. ..$ : chr [1:2] "Nino3.4_degree_1974_2000" "Houlgrave_flow_1974_2000"
  Index:  Date[1:15], format: "1991-05-15" "1991-06-15" ...
 $ :‘zoo’ series from 1993-02-15 to 1993-07-15
  Data: num [1:6, 1:2] 0.54 0.641 1.01 1.144 0.917 ...
  ..- attr(*, "dimnames")=List of 2
  .. ..$ : NULL
  .. ..$ : chr [1:2] "Nino3.4_degree_1974_2000" "Houlgrave_flow_1974_2000"
  Index:  Date[1:6], format: "1993-02-15" "1993-03-15" ...
 $ :‘zoo’ series from 1994-08-15 to 1995-02-15
  Data: num [1:7, 1:2] 0.662 0.746 1.039 1.329 1.301 ...
  ..- attr(*, "dimnames")=List of 2
  .. ..$ : NULL
  .. ..$ : chr [1:2] "Nino3.4_degree_1974_2000" "Houlgrave_flow_1974_2000"
  Index:  Date[1:7], format: "1994-08-15" "1994-09-15" ...
 $ :‘zoo’ series from 1997-04-15 to 1998-05-15
  Data: num [1:14, 1:2] 0.601 1.136 1.461 1.668 2.079 ...
  ..- attr(*, "dimnames")=List of 2
  .. ..$ : NULL
  .. ..$ : chr [1:2] "Nino3.4_degree_1974_2000" "Houlgrave_flow_1974_2000"
  Index:  Date[1:14], format: "1997-04-15" "1997-05-15" ...
> 

抱歉,我不知道如何格式化。

【问题讨论】:

标签: r list merge dataframe zoo


【解决方案1】:

你试过这个功能吗:

http://rss.acs.unt.edu/Rdoc/library/gtools/html/smartbind.html

out <- smartbind(list_of_dataframes)

注意:list_of_dataframes 应该包含 data.frames,但您可以将数据动态转换为 dframe,然后使用此函数。

【讨论】:

    【解决方案2】:

    如果日期不重叠,您可以使用rbind 将它们粘贴在一起(因为每个组件的列数相同)。试试:

    el_nino_1974_2000_all <- c()
    for (k in seq_along(el_nino_start_month)){
        el_nino_1974_2000_all <- rbind(el_nino_1974_2000_all,window(...))
    }
    

    而不是您最初拥有的 list 构造。 这将返回一个zoo 对象。

    如果您想返回data.frame,请尝试使用rbind,但使用data.frame 来转换您的对象(即使您的每个数据集之间的日期索引重叠也可以):

    el_nino_1974_2000_all <- data.frame()
    for (k in seq_along(el_nino_start_month)){
        el_nino_1974_2000_all <- rbind(el_nino_1974_2000_all,data.frame(window(...)))
    }
    

    【讨论】:

      猜你喜欢
      • 2021-10-18
      • 2013-12-13
      • 2017-10-21
      • 2022-01-15
      • 2013-06-14
      • 1970-01-01
      • 1970-01-01
      • 2020-12-31
      • 2018-05-20
      相关资源
      最近更新 更多