利用变量值/类型重命名列

时间:2017-08-03 05:30:59

标签: r dplyr data-management

我已经搜索了stackoverflow以获得这个问题的答案,但到目前为止还没有运气。我的要求:

对于简单的数据框:

# create dummy data.frame
d <- data.frame(var1 = as.character(1:5), 
                var2 = factor(letters[1:5]), 
                var3 = 1:5, stringsAsFactors = FALSE,
                var4 = rep("<div class='The mink cat'< /p>'",5))

如何根据变量类型/字符串内容重命名变量而不引用原始列名称(例如,d [,1]或var1)?

将var1-var3重命名为每个变量中值类型给出的字符,因子和数字。

通过搜索变量值并利用字符串的一部分将'varink'重命名为'mink':'the mink cat'。

3 个答案:

答案 0 :(得分:2)

使用purrr库获得更简化的代码

library(purrr)
colnames(d) <- map_chr(d, class)

d

  character factor integer                       character
1         1      a       1 <div class='The mink cat'< /p>'
2         2      b       2 <div class='The mink cat'< /p>'
3         3      c       3 <div class='The mink cat'< /p>'
4         4      d       4 <div class='The mink cat'< /p>'
5         5      e       5 <div class='The mink cat'< /p>'

答案 1 :(得分:1)

也许是这样的:

colnames(d) = lapply(d,class)
colnames(d)[sapply(d, function(x) any(grepl("cat",x)))] = "mink"

输出:

  character factor integer                            mink
1         1      a       1 <div class='The mink cat'< /p>'
2         2      b       2 <div class='The mink cat'< /p>'
3         3      c       3 <div class='The mink cat'< /p>'
4         4      d       4 <div class='The mink cat'< /p>'
5         5      e       5 <div class='The mink cat'< /p>'

最后一列重命名为'mink',因为它包含'mink'。

答案 2 :(得分:1)

正如我们之前评论的那样,解决方案是找到class列的sapply,然后使用该对象命名列('nm1'),最后命名unlist第一行,获取具有'mink'的列的索引,并将列名称分配给'mink'

nm1 <- sapply(d, class)
names(d) <- nm1
names(d)[grep("mink", unlist(d[1,]))] <- "mink"
d
#  character factor integer                            mink
#1         1      a       1 <div class='The mink cat'< /p>'
#2         2      b       2 <div class='The mink cat'< /p>'
#3         3      c       3 <div class='The mink cat'< /p>'
#4         4      d       4 <div class='The mink cat'< /p>'
#5         5      e       5 <div class='The mink cat'< /p>'