Вот данные и вектор.
df1 <- tibble(var1 = c("abcd", "efgh", "ijkl", "qrst"))
vec <- c("abcd", "mnop", "ijkl")
Теперь для всех значений в var1, совпадающих со значениями в vec, оставьте только первые 3 символа в var1, так что желаемое решение:
df2 <- tibble(var1 = c("abc", "efgh", "ijk", "qrst"))
Поскольку "abcd" соответствует, мы сохраняем только 3 символа, то есть "abc" в df2, но "efgh" не существует в vec, поэтому мы сохраняем его, как и "efgh" в df2.
Как я могу использовать dplyr и / или stringr для этого?