【问题标题】:R rename columns dynamically and ignore missingR动态重命名列并忽略丢失
【发布时间】:2020-11-18 20:09:52
【问题描述】:

我有一个需要动态重命名特定列的数据集。

例如,我通常会按以下方式重命名“mtcars”数据集:

# THIS WORKS    
# Load data
data <- mtcars

# Gather data.frame with columns to rename, I am doing it this way because I generally have 
# a long list of "configurations" to plot that I go through in a for loop.  Might not be the most 
# efficient, but it generally works for me.
Columns_to_rename <- data.table(X = "mpg", Y = "gear", Color = "carb")

# Rename columns
plot_data <- data %>%
    dplyr::rename(X := !!Columns_to_rename$X[1],
                  Y := !!Columns_to_rename$Y[1],
                  Color := !!Columns_to_rename$Color[1]) %>%
    dplyr::select(X, Y, Color)

但是,在我的真实数据集中具有真实的Columns_to_rename,我的数据集可能不包含标题。我只想忽略重命名。

考虑上例中的情况:

Columns_to_rename <- data.table(X = "mpg", Y = "gear", Color = "missing")

据我所知,dplyr 包要求所有列都存在。坚持使用tidyverse,我考虑使用plyr 包,因为我知道这允许丢失列名。不幸的是,我无法弄清楚如何动态调用列。我查看了以前的 StackOverflow 问题和答案,但没有看到有人需要在重命名时结合这两个原则。

谢谢!

【问题讨论】:

  • 我知道一般情况下最好避免这种情况,但在这种情况下,您可以按位置调用未命名的列吗?
  • 那行不通,因为我的“Columns_to_rename”在每次迭代之间都会发生变化,因此列号会随着每次迭代而变化。但是谢谢你的想法!

标签: r


【解决方案1】:

一个选项是使用%in% 进行子集化

library(dplyr)
nm1 <- unlist(Columns_to_rename)
nm2 <-  nm1[nm1 %in% names(data)]
data %>% 
      rename(!!! nm2) %>%
      select(names(nm2)) %>%
      head

-输出

#                    X Y
#Mazda RX4         21.0 4
#Mazda RX4 Wag     21.0 4
#Datsun 710        22.8 4
#Hornet 4 Drive    21.4 3
#Hornet Sportabout 18.7 3
#Valiant           18.1 3

或者另一个选项是子集向量('nm2')上的rename_atrename_with

data %>%
    rename_at(vars(all_of(nm2)), ~ names(nm2)) %>%
    select(names(nm2)) %>%
    head

注意:我们也可以在“nm1”上使用any_of 进行换行,但问题是names(nm1) 的长度会不匹配

data %>% 
      rename_at(vars(any_of(nm1)), ~ names(nm2))

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-03-27
    • 2021-10-16
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多