gpt4 book ai didi

将具有两列的data.frame reshape 为具有数据的多列(R)

转载 作者:行者123 更新时间:2023-12-04 10:15:10 25 4
gpt4 key购买 nike

一个微不足道的问题,但我至今找不到答案。

我想将数据框列“年”拆分为一组新列,其中每年的列名和后续数据如下:

    Year     FQ
1975 3.156
1975 8.980
1977 10.304
1977 7.861
1979 4.729
1979 7.216
1981 4.856
1981 3.438
1983 9.887
1983 3.850

所需的输出:
1975    1977    1979   1981    1983 

3.156 10.304 4.729 4.856 9.887
8.980 7.861 7.216 3.438 3.850

样本数据:
d<-structure(list(Year = structure(1:10, .Label = c("1975", "1975", 
"1977", "1977", "1979", "1979", "1981", "1981", "1983", "1983",
"1985", "1985", "1987", "1987", "1988", "1988", "1991", "1991",
"1993", "1993", "1995", "1995", "1997", "1997", "2000", "2000",
"2001", "2001", "2003", "2003", "2005", "2005", "2007", "2007",
"2009", "2009", "2011", "2011"), class = "factor"), FQ = c(3.156,
8.98, 10.304, 7.861, 4.729, 7.216, 4.856, 3.438, 9.887, 3.85)), .Names = c("Year",
"FQ"), class = "data.frame", row.names = c(1L, 62L, 123L, 184L,
245L, 306L, 367L, 428L, 489L, 550L))

我试过融化数据:
melt(d, id.vars = "Year")

然后使用类型转换:
cast(d, Year~value) 

并 reshape
d1<-reshape(d, idvar="Year", timevar="FQ", direction="wide")

但无济于事

最佳答案

您实际上并没有“ID”变量,因此您需要创建一个。如果 Year 会更容易是 character变量,所以除了添加一个“ID”变量之外,我还在下面进行了转换:

d <- within(d, {
Year <- as.character(Year)
ID <- ave(Year, Year, FUN=seq_along)
})

从这里开始,很容易使用 dcast直接地...
library(reshape2)
dcast(d, ID ~ Year, value.var="FQ")
# ID 1975 1977 1979 1981 1983
# 1 1 3.156 10.304 4.729 4.856 9.887
# 2 2 8.980 7.861 7.216 3.438 3.850

... 或 reshape .
reshape(d, direction  = "wide", idvar="ID", timevar="Year")
# ID FQ.1975 FQ.1977 FQ.1979 FQ.1981 FQ.1983
# 1 1 3.156 10.304 4.729 4.856 9.887
# 62 2 8.980 7.861 7.216 3.438 3.850

关于将具有两列的data.frame reshape 为具有数据的多列(R),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20373797/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com