gpt4 book ai didi

r - 将一列拆分为多列

转载 作者:行者123 更新时间:2023-12-02 18:36:12 25 4
gpt4 key购买 nike

我有一个巨大的数据集,其中有一列包含每个主题(行)的多个值。这是一个简化的示例数据框:

data <- data.frame(subject = c(1:8), sex = c(1, 2, 2, 1, 2, 1, 1, 2), 
age = c(35, 29, 31, 46, 64, 57, 49, 58),
v1 = c("2", "0", "3,5", "2 1", "A,4", "B,1,C", "A and B,3", "5, 6 A or C"))

> data
subject sex age v1
1 1 1 35 2
2 2 2 29 0
3 3 2 31 3,5 # separated by a comma
4 4 1 46 2 1 # separated by a blank space
5 5 2 64 A,4
6 6 1 57 B,1,C
7 7 1 49 A and B,3
8 8 2 58 5, 6 A or C

我首先要删除第四列 ( v1),然后将第四列分成多列,如下所示:

  subject sex age x1 x2 x3 x4 x5 x6
1 1 1 35 0 1 0 0 0 0
2 2 2 29 0 0 0 0 0 0
3 3 2 31 0 0 1 0 1 0
4 4 1 46 1 1 0 0 0 0
5 5 2 64 0 0 0 1 0 0
6 6 1 57 1 0 0 0 0 0
7 7 1 49 0 0 1 0 0 0
8 8 2 58 0 0 0 0 1 1

其中,第一个受试者在 x2 处取 1,因为它在原始数据集中的 v1 处取 2,第三个受试者在 x3 和 x5 处均取 1,因为它在原始数据集中的 v1 处取 3 和 5,依此类推。

如果对这个问题有任何帮助,我将不胜感激。非常感谢。

最佳答案

您可以将此结果绑定(bind)到 data[-4] 并获得您需要的内容:

 0+t(sapply(as.character(data$v1), function(line) 
sapply(1:6, function(x) x %in% unlist(strsplit(line, split="\\s|\\,"))) ))
#----------------
[,1] [,2] [,3] [,4] [,5] [,6]
2 0 1 0 0 0 0
0 0 0 0 0 0 0
3,5 0 0 1 0 1 0
2 1 1 1 0 0 0 0
A,4 0 0 0 1 0 0
B,1,C 1 0 0 0 0 0
A and B,3 0 0 1 0 0 0
5, 6 A or C 0 0 0 0 1 1

关于r - 将一列拆分为多列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14760730/

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