Как перекодировать множественные условия в -1/0/+1?
У меня есть такие данные, как:
Name A B C
apple 1 -1 0
banana 2 -2 1
pear -3 0 1
Я хочу заменить все положительные значения на -1, все отрицательные значения на +1, но оставить 0, чтобы быть 0, как мне этого добиться?
2 ответа
Решение
Мы могли бы использовать sign
чтобы получить знак всех элементов кадра данных, а затем обратить его, умножив его на -1.
df[-1] <- sign(df[-1]) * -1
df
# Name A B C
#1 apple -1 1 0
#2 banana -1 1 -1
#3 pear 1 0 -1
От ?sign
знак возвращает вектор со знаками соответствующих элементов x (знак действительного числа равен 1, 0 или -1, если число положительное, ноль или отрицательное, соответственно).
данные
df <- structure(list(Name = structure(1:3, .Label = c("apple", "banana",
"pear"), class = "factor"), A = c(-1, -1, 1), B = c(1, 1, 0),
C = c(0, -1, -1)), .Names = c("Name", "A", "B", "C"), row.names = c(NA,
-3L), class = "data.frame")
Это ни в коем случае не так хорошо, как проголосовавший верх, но вот альтернатива:
ans <- df1[,-1] / -abs(df1[,-1])
ans[sapply(ans,is.nan)] <- 0
#> ans
# A B C
#1 -1 1 0
#2 -1 1 -1
#3 1 0 -1