Я пытаюсь создать новый столбец в моем наборе данных, который говорит мне, если доход продукта равен 0 с за все 3 месяца, некоторые 0 за все 3 месяца или не 0 для всех 3 месяца.Создайте новый столбец из условий в вложенных циклах
Я представил NewColumn
как бы хотел, чтобы результат выглядел.
data$ZEROES <- 0
data$ZEROES2 <- 0
for (i in unique(data$product_id)){
for (j in unique(data$Revenue)){
n[j] <-ifelse(all(data$Value == 0)," ALL 0",
ifelse(any(data$Value == 0),"Some 0",
ifelse(all(data$Value != 0), "None 0", "Blank")))
data$ZEROES[j] <-n[j]
data$ZEROES2[i] <-long$ZEROES[j]
}
}
product_ id Date Revenue Value NewColumn
1 January in 0 Some 0
1 February in 1 Some 0
1 March in 0 Some 0
1 January out 0 All 0
1 February out 0 All 0
1 March out 0 All 0
2 January in 1 No 0
2 February in 2 No 0
2 March in 3 No 0
2 January out 1 Some 0
2 February out 1 Some 0
2 March out 0 Some 0
данных
structure(list(product_id = c(1L, 1L, 1L, 1L, 1L, 1L, 2L, 2L, 2L, 2L, 2L, 2L),
Date = c("January", "February", "March", "January", "February", "March", "January", "February", "March", "January", "February", "March"),
Revenue = c("in", "in", "in", "out", "out", "out", "in", "in", "in", "out", "out", "out"),
Value = c(0L, 1L, 0L, 0L, 0L, 0L, 1L, 2L, 3L, 1L, 1L, 0L),
NewColumn = c("Some 0", "Some 0", "Some 0", "All 0", "All 0", "All 0", "No 0", "No 0", "No 0", "Some 0", "Some 0", "Some 0")),
.Names = c("product_id", "Date", "Revenue", "Value", "NewColumn"),
class = "data.frame", row.names = c(NA, -12L))
Не дай бог вам добавить данные, которые вы использовали в своих ответах для других – rawr
Хороший звонок, я обычно стараюсь включить его (как напоминание OP) и забыл на этот раз, я рад, что @ flightless13wings обратил внимание:) – r2evans
Поблагодарите @rawr за редактирование моего первоначального вопроса и добавление данных. – flightless13wings