Я пытаюсь выяснить, как создать новый столбец в R, который учитывает, остается ли политик «i» в той же партии или дефекта для данных законодательных органов "l". Эти политики и партии признаются из-за индексов. Вот пример того, как мои данные первоначально выглядит следующим образом:Q-Как заполнить новый столбец в data.frame на основе значений строк двумя условиями в R
## example of data
names <- c("Jesus Martinez", "Anrita blabla", "Paco Pico", "Reiner Steingress", "Jesus Martinez Porras")
Parti.affiliation <- c("Winner","Winner","Winner", "Loser", NA)#NA, "New party", "Loser", "Winner", NA
Legislature <- c(rep(1, 5), rep(2,5), rep(3,5), rep(4,5), rep(5,5), rep(6,5))
selection <- c(rep("majority", 15), rep("PR", 15))
sex<- c("Male", "Female", "Male", "Female", "Male")
Election<- c(rep(1955, 5), rep(1960, 5), rep(1965, 5), rep(1970,5), rep(1975,5), rep(1980,5))
d<- data.frame(names =factor(rep(names, 6)), party.affiliation = c(rep(Parti.affiliation,5), NA, "New party", "Loser", "Winner", NA), legislature = Legislature, selection = selection, gender =rep(sex, 6), Election.date = Election)
## genrating id for politician and party.affiliation
d$id_pers<- paste(d$names, sep="")
d <- arrange(d, id_pers)
d <- transform(d, id_pers = as.numeric(factor(id_pers)))
d$party.affiliation1<- as.numeric(d$party.affiliation)
Ожидаемый результат должен показать следующее: если политик (показал через колонку «id_pers») изменил свои значения в столбце «party.affiliation1 », значение 1 будет присвоено в новом столбце под названием„переключатель“, в противном случае 0. То же процедура должна быть выполнена с каждым политиком в наборе данных, поэтому ожидаемый результат должен быть такой:
d["switch"]<- c(1, rep(0,4), NA, rep(0,6), rep(NA, 6),1, rep(0,5), rep (0,5),1) # 0= remains in the same party/1= switch party affiliation.
As Например, вы можете видеть в этом data.frame, что первый политик, получивший название «Anrita blabla», был кандидатом от партии «3» от 1-го до 5-го законодательного органа. Однако мы можем заметить, что «Антрита» меняет свою партийную принадлежность в 6-м законодательном органе, поэтому она была кандидатом на партию «2». Поэтому новый столбец «switch» должен содержать значение «1», чтобы отразить изменение Анриты в партийной принадлежности и «0», чтобы показать, что «Anrita» не изменила свою партийную принадлежность для первых 5 законодательных органов.
Я пробовал несколько подходов, чтобы сделать это (например, петли). Я нашел эту стратегию простейший, но он не работает :(
## add a new column based on raw values
ind <- c(FALSE, party.affiliation1[-1L]!= party.affiliation1[-length(party.affiliation1)] & party.affiliation1!= 'Null')
d <- d %>% group_by(id_pers) %>% mutate(this = ifelse(ind, 1, 0))
Я надеюсь, что вы нашли это объяснение ясно, спасибо заранее !!!
Спасибо Jaime Caffarel и @Haboryme. Тем не менее позвольте мне спросить, возможно ли в вашей строке кода сказать R: «присвойте значение 99 этим первым элементам». Таким образом, я могу различать те реальные недостающие ценности и те случаи, которые у меня есть информация об их партийной принадлежности. =) –
Да, см. Мое редактирование. – Haboryme
Спасибо !!!Я люблю ваш ответ, короткий и сладкий :) –