So benennen Sie ausgewählte Spalten mit dplyr mit neuen Spaltennamen als strings

Habe ich Folgendes tibble:

library(tidyverse)
df <- structure(list(Sepal.Length = c(5.1, 4.9, 4.7, 4.6, 5), Sepal.Width = c(3.5, 
3, 3.2, 3.1, 3.6), Petal.Length = c(1.4, 1.4, 1.3, 1.5, 1.4)), .Names = c("Sepal.Length", 
"Sepal.Width", "Petal.Length"), row.names = c(NA, 5L), class = c("tbl_df", 
"tbl", "data.frame"))

Sieht liegen diese:

> df
# A tibble: 5 × 3
  Sepal.Length Sepal.Width Petal.Length
*        <dbl>       <dbl>        <dbl>
1          5.1         3.5          1.4
2          4.9         3.0          1.4
3          4.7         3.2          1.3
4          4.6         3.1          1.5
5          5.0         3.6          1.4

Was ich tun möchte, ist zu ersetzen Sepal.Length und Petal.Length mit angehängtem string to_app <- ".xxx" ergibt:

  Sepal.Length.xxx Sepal.Width Petal.Length.xxx
          5.1         3.5          1.4
          4.9         3.0          1.4
          4.7         3.2          1.3
          4.6         3.1          1.5
          5.0         3.6          1.4

Habe ich versucht, diese mit Fehler:

>df %>% rename(paste(Sepal.Length,to_app,sep="") = Petal.Length,paste(Sepal.Width,to_app,sep="") = Petal.Length)
Error: unexpected '=' in "df %>% rename(paste(Sepal.Length,to_app,sep="") ="
Nur ein weiterer R-Konstruktion, dies zu tun, verwenden match - vars <- c("Sepal.Length", "Sepal.Width"); names(df)[match(vars, names(df))] <- paste0(vars, to_app)

InformationsquelleAutor neversaint | 2017-04-19

Schreibe einen Kommentar