R语言列筛选的方法select实例详解

 更新时间:2022年07月14日 11:47:10   作者:育种数据分析之放飞自我  
对于大数据,linux和python是很好的处理工具,但是对于这两个语言不熟悉的盆友来说,R语言是非常好的替代工具,下面这篇文章主要给大家介绍了关于R语言列筛选的法select的相关资料,需要的朋友可以参考下

前言

我们知道,R语言学习,80%的时间都是在清洗数据,而选择合适的数据进行分析和处理也至关重要,如何选择合适的列进行分析,你知道几种方法?

如何优雅高效的选择合适的列,让我们一起来看一下吧。

1. 数据描述

数据来源是我编写的R包learnasreml中的fm数据集。

r$> library(learnasreml)

r$> data(fm)

r$> head(fm)

我们的目的:

提取fm的TreeID,Rep,dj,dm,h3,并重命名为:ID, F1, y1 , y2, y3

2. 使用R语言默认的方法:列选择

这一种,当然是简单粗暴的方法,想要哪一列,就把相关的列号提取出来,形成一个向量,进行操作即可。比如

r$> d1 = fm[,c(1,3,6,7,11)]

r$> head(d1)
  TreeID Rep    dj    dm  h3
1  80001   1 0.334 0.405 239
2  80002   1 0.348 0.393 242
3  80004   1 0.354 0.429 180
4  80005   1 0.335 0.408 301
5  80008   1 0.322 0.372 271
6  80026   1 0.359 0.450 258

r$> names(d1) = c("ID","F1","y1","y2","y3")

r$> head(d1)

结果:

缺点:

这种方法,需要找到性状所在的列号,然后还要重命名,比较麻烦。

而且,后面如果想要根据列的特征进行提取时(比如以h开头的列,比如属性为数字或者因子的列等等),就不能实现了。

这就要用到tidyverse的函数了,selectrename,都是一等一的良将。

3. tidyverse的rename函数

代码:

a2 = fm %>% rename(ID=TreeID, F1 = Rep, y1 = dj, y2 = dm, y3 = h3)

这里,rename只是单独的修改名称,并没有提取出来。

还要使用select进一步的提取:

4. tidyverse的select函数

如果使用select函数,一行代码就可以搞定:

a1 = fm %>% select(ID=TreeID, F1 = Rep, y1 = dj, y2 = dm, y3 = h3)

5. select函数注意事项

常见的坑:

注意,MASS包中也有select函数,而且优先级更高,如果你载入了MASS包,select就不能使用了。

哪怕你再次载入tidyverse包,也不行:

载入dplyr包,也不行:

MASS就是这么豪横。

像这种情况,解决办法有两种:

5.1 绝对引用函数

即使用select时,要用dplyr::select

a3 = a2 %>% dplyr::select(ID,F1,y1,y2,y3)

这样也比较麻烦。

5.2 放到环境变量中

推荐的方法:

r$> select = dplyr::select

r$> a3 = a2 %>% select(ID,F1,y1,y2,y3)

推荐在载入包时,将下面代码放在开头,就可以肆无忌惮的应用select了,毕竟,环境变量的优先级是第一位的。

library(tidyverse)
select = dplyr::select

6. 提取h开头的列

这里,用starts_with,会匹配开头为h的列。

其它还有contains,匹配包含的字符,还有end_with,匹配结尾的字符。

应有尽有,无所不有。

re1 = fm %>% select(starts_with("h"))

7. 提取因子和数字的列

匹配数字的列:

re2 = fm %>% select_if(is.numeric)

匹配为因子的列:

re3 = fm %>% select_if(is.factor)

总结

到此这篇关于R语言列筛选的方法select的文章就介绍到这了,更多相关R语言列筛选select内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • R语言绘图-点图dot plot

    R语言绘图-点图dot plot

    这篇文章主要介绍了R语言绘图-点图dot plot案例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-04-04
  • R语言-summary()函数的用法解读

    R语言-summary()函数的用法解读

    这篇文章主要介绍了R语言-summary()函数的用法解读,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-04-04
  • R语言绘制corrplot相关热图分析美化示例及详细图解

    R语言绘制corrplot相关热图分析美化示例及详细图解

    这篇文章主要为大家介绍了R语言corrplot相关热图分析美化示例及详细图解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06
  • 教你利用R语言测试电脑的性能

    教你利用R语言测试电脑的性能

    这篇文章主要介绍了利用R语言测试电脑的性能如何,通过矩阵的运算来计算,本文通过代码讲解的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-04-04
  • R语言-实现提取包含某字符串的行变量

    R语言-实现提取包含某字符串的行变量

    这篇文章主要介绍了R语言-实现提取包含某字符串的行变量,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-04-04
  • R语言初学者的一些常见报错指南

    R语言初学者的一些常见报错指南

    在使用R的时候,偶尔也会遇到一些糟心的报错,本文把运行过程中遇到的一些报错和解决方案进行总结归纳,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2022-08-08
  • R语言中矩阵matrix和数据框data.frame的使用详解

    R语言中矩阵matrix和数据框data.frame的使用详解

    这篇文章主要介绍了R语言中矩阵matrix和数据框data.frame的使用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03
  • R语言glmnet包lasso回归中分类变量的处理图文详解

    R语言glmnet包lasso回归中分类变量的处理图文详解

    Lasso回归又称为套索回归,是Robert Tibshirani于1996年提出的一种新的变量选择技术,下面这篇文章主要给大家介绍了关于R语言glmnet包lasso回归中分类变量的处理的相关资料,需要的朋友可以参考下
    2022-11-11
  • 使用R语言填补缺失值的方法

    使用R语言填补缺失值的方法

    这篇文章主要介绍了使用R语言填补缺失值的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-03-03
  • R语言ggplot2包之注释方式

    R语言ggplot2包之注释方式

    这篇文章主要介绍了R语言ggplot2包之注释方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-04-04

最新评论