Как заменить строковые значения в столбце на основе таблицы поиска - PullRequest
1 голос
/ 23 мая 2019

У меня есть этот DF.Я хотел бы заменить каждый экземпляр "1.1", "2.1", "3.2" и т. Д. На основе таблицы поиска.

enter image description here

Lookupтаблица

enter image description here

Желаемый вывод

enter image description here

Я смотрел на Заменить значения в кадре данных на основе таблицы поиска Это не решит мою проблему.Заранее спасибо!

1 Ответ

2 голосов
/ 23 мая 2019

Опция будет gsubfn. Мы сопоставляем одну или несколько цифр с точкой ([0-9.]+) в качестве шаблона и при замене передаем list пар ключ / значение, созданных из второго набора данных ('df2'). Для соответствующего шаблона с «ключами» он заменяет соответствующее «значение» в строке

library(gsubfn)
df1$Node <- gsubfn("([0-9.]+)", as.list(setNames(df2$Label,df2$Node)), df1$Node)
df1$Node
#[1] "One one > Two one > Three two" "One two > Two two > Three one" "One one > Two two > Three one" "One two > Two one > Three two"
#[5] "One one > Two two > Three two"

данные

df1 <- data.frame(ID = 1:5, Node = c("1.1 > 2.1 > 3.2", "1.2 > 2.2 > 3.1", "1.1 > 2.2 > 3.1", "1.2 > 2.1 > 3.2", "1.1 > 2.2 > 3.2"), stringsAsFactors = FALSE)

df2 <- data.frame(Label =  c("One one", "One two", "Two one", "Two two", "Three one", "Three two"), Node = c("1.1", "1.2", "2.1", "2.2", "3.1", "3.2"), stringsAsFactors = FALSE)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...