2016-08-08 83 views
-1

在我的特殊情況下,我想根據條件將數據幀列中的數據轉換爲布爾值/邏輯值。但我認爲我的問題可以用於每個對話/轉換擁有一個數據框列?轉換或轉換R中的數據幀的列

實施例:

> sleep 
    extra group ID 
1 0.7  1 1 
2 -1.6  1 2 
3 -0.2  1 3 
4 -1.2  1 4 
5 -0.1  1 5 
6 3.4  1 6 
7 3.7  1 7 
8 0.8  1 8 
9 0.0  1 9 
10 2.0  1 10 
11 1.9  2 1 
12 0.8  2 2 
13 1.1  2 3 
14 0.1  2 4 
15 -0.1  2 5 
16 4.4  2 6 
17 5.5  2 7 
18 1.6  2 8 
19 4.6  2 9 
20 3.4  2 10 
> L = sleep$extra < 0 
> L 
[1] FALSE TRUE TRUE TRUE TRUE FALSE FALSE FALSE FALSE FALSE FALSE FALSE 
[13] FALSE FALSE TRUE FALSE FALSE FALSE FALSE FALSE 

我想L爲數據幀(或一個新的)內的一列。

+0

downvote沒有評論?我的問題愚蠢? – buhtz

回答

1

這將添加一個名爲L的新列,併爲其分配值(sleep$extra < 0)。

sleep["L"] <- sleep$extra < 0 


# extra group ID  L 
#1 0.7  1 1 FALSE 
#2 -1.6  1 2 TRUE 
#3 -0.2  1 3 TRUE 
#4 -1.2  1 4 TRUE 
#5 -0.1  1 5 TRUE 
#6 3.4  1 6 FALSE 
#7 3.7  1 7 FALSE 
#8 0.8  1 8 FALSE 
#9 0.0  1 9 FALSE 
#10 2.0  1 10 FALSE 
#11 1.9  2 1 FALSE 
#12 0.8  2 2 FALSE 
#13 1.1  2 3 FALSE 
#14 0.1  2 4 FALSE 
#15 -0.1  2 5 TRUE 
#16 4.4  2 6 FALSE 
#17 5.5  2 7 FALSE 
#18 1.6  2 8 FALSE 
#19 4.6  2 9 FALSE 
#20 3.4  2 10 FALSE 

,或者你可以cbind

cbind(sleep, L) 

將新列(L)添加到您的sleep數據幀。

如果您想用布爾值/邏輯值替換同一列(extra),您可以將值分配給同一個變量。

sleep$extra <- sleep$extra < 0 


# extra group ID 
#1 FALSE  1 1 
#2 TRUE  1 2 
#3 TRUE  1 3 
#4 TRUE  1 4 
#5 TRUE  1 5 
#6 FALSE  1 6 
#7 FALSE  1 7 
#8 FALSE  1 8 
#9 FALSE  1 9 
#10 FALSE  1 10 
#11 FALSE  2 1 
#12 FALSE  2 2 
#13 FALSE  2 3 
#14 FALSE  2 4 
#15 TRUE  2 5 
#16 FALSE  2 6 
#17 FALSE  2 7 
#18 FALSE  2 8 
#19 FALSE  2 9 
#20 FALSE  2 10 
+0

這到底是什麼?你能解釋一下你的解決方案嗎? – buhtz

+1

@buhtz補充說明! –

1

您可以以多種方式變換列

sleep <- within(sleep, l <- extra < 0) (or) 

sleep <- transform(sleep, l = extra<0) (or) 

library(dplyr) 
sleep <- sleep %>% 
    mutate(L = extra < 0) 

extra group ID  L 
1 0.7  1 1 FALSE 
2 -1.6  1 2 TRUE 
3 -0.2  1 3 TRUE 
4 -1.2  1 4 TRUE 
5 -0.1  1 5 TRUE 
6 3.4  1 6 FALSE 
7 3.7  1 7 FALSE 
8 0.8  1 8 FALSE 
9 0.0  1 9 FALSE 
10 2.0  1 10 FALSE 
11 1.9  2 1 FALSE 
12 0.8  2 2 FALSE 
13 1.1  2 3 FALSE 
14 0.1  2 4 FALSE 
15 -0.1  2 5 TRUE 
16 4.4  2 6 FALSE 
17 5.5  2 7 FALSE 
18 1.6  2 8 FALSE 
19 4.6  2 9 FALSE 
20 3.4  2 10 FALSE