Кто-нибудь знает, как скопировать столбец в data.frame
и добавить префикс в новый столбец?Скопируйте столбец и добавьте префикс в новый столбец в R с помощью dplyr
Идея состоит в том, чтобы иметь вектор символов, содержащий определенные имена столбцов в кадре данных, и скопировать их с префиксом, чтобы впоследствии выполнить действие.
Причина в том, что я хочу использовать функцию распространения в этих столбцах, но насколько я знаю, функция распространения не сохраняет исходный столбец. То, что я хотел бы:
От в data.frame со следующими именами столбцов:
column_names <- c('var1', 'var2', 'var3')
К dataframe со следующими столбцами
column_names <- c('var1', 'var2', 'var3', 'prefix_var1','prefix_var3')
Где столбцы с «приставкой» содержат те же данные, что и их оригинальные столбцы.
То, что я пытался до сих пор, что частично удалось:
sel_columns <- c('var1', 'var3')
data <- data.frame(var1 = c(12,3,4), var2 = c(123,5435,121), var3 = c(23,456,123))
new_data <- data %>% mutate_at(one_of(sel_columns), funs(.))
#Error in eval(substitute(expr), envir, enclos) :
# could not find function "var1"
#In addition: Warning message:
#In one_of(sel_columns) : Unknown variables: `var1`, `var3`
new_data2 <- data %>% select(one_of(sel_columns)) %>% mutate_all(funs(prefix = . * 1)) %>% c(data, .) %>% data.frame
Я обнаружил, что это действительно работает на примере я представил, однако для моего примера это привело к data.frame двух столбцов, один, имеющим название «данные», и другие имеют название «V2». Я обнаружил, что с помощью функции c() функции cbind() она работает правильно. – Michael
@ Майкл. Я не уверен, в чем проблема. Можете ли вы опубликовать 'dput (head (data))', чтобы получить реальный набор данных? –
, если вы действительно хотите добавить аромат dplyr: 'bind_cols (data, setNames (data [sel_columns], paste0 (" prefix _ ", sel_columns)))' –