前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >R语言中多条件排序

R语言中多条件排序

作者头像
邓飞
发布2022-04-06 19:36:29
5970
发布2022-04-06 19:36:29
举报

R语言中,如何对数据框的数据根据某个条件进行排序呢?如何根据多条件进行排序呢,类似Excel中的排序效果:

1. 示例数据

R语言中鸢尾花的数据,数据有五列:

代码语言:javascript
复制
> names(iris)
[1] "Sepal.Length" "Sepal.Width"  "Petal.Length" "Petal.Width"  "Species" 

前五行数据预览:

代码语言:javascript
复制
> head(iris)
  Sepal.Length Sepal.Width Petal.Length Petal.Width Species
1          5.1         3.5          1.4         0.2  setosa
2          4.9         3.0          1.4         0.2  setosa
3          4.7         3.2          1.3         0.2  setosa
4          4.6         3.1          1.5         0.2  setosa
5          5.0         3.6          1.4         0.2  setosa
6          5.4         3.9          1.7         0.4  setosa

2. 使用R中自带函数order

第一列升序,然后是第三列升序

这里的iris[,1]是数据的第一列

代码语言:javascript
复制
r1 = iris[order(iris[,1],iris[3]),]
head(r1)

结果:

代码语言:javascript
复制
> # 第一列升序,然后是第三列升序
> r1 = iris[order(iris[,1],iris[3]),]
> head(r1)
   Sepal.Length Sepal.Width Petal.Length Petal.Width Species
14          4.3         3.0          1.1         0.1  setosa
39          4.4         3.0          1.3         0.2  setosa
43          4.4         3.2          1.3         0.2  setosa
9           4.4         2.9          1.4         0.2  setosa
42          4.5         2.3          1.3         0.3  setosa
23          4.6         3.6          1.0         0.2  setosa

如果想要第一列升序,第三列降序呢,在第三列前面加上一个“-”符号:

代码语言:javascript
复制
r2 = iris[order(iris[,1],-iris[3]),]
head(r2)

结果:

代码语言:javascript
复制
> # 第一列升序,然后是第三列降序
> r2 = iris[order(iris[,1],-iris[3]),]
> head(r2)
   Sepal.Length Sepal.Width Petal.Length Petal.Width Species
14          4.3         3.0          1.1         0.1  setosa
9           4.4         2.9          1.4         0.2  setosa
39          4.4         3.0          1.3         0.2  setosa
43          4.4         3.2          1.3         0.2  setosa
42          4.5         2.3          1.3         0.3  setosa
4           4.6         3.1          1.5         0.2  setosa

3. 使用dplyrarrange

R包dplyr的函数arrange,更简单,更简洁:

代码语言:javascript
复制
# 多条件排序:使用dplyr::arrange
library(dplyr)
data("iris")
head(iris)

# 第一列升序,然后是第三列升序
arrange(iris,iris[,1],iris[,3])

# 第一列升序,然后是第三列降序
arrange(iris,iris[,1],-iris[,3])

结果:

代码语言:javascript
复制
> # 多条件排序:使用dplyr::arrange
> library(dplyr)
> data("iris")
> head(iris)
  Sepal.Length Sepal.Width Petal.Length Petal.Width Species
1          5.1         3.5          1.4         0.2  setosa
2          4.9         3.0          1.4         0.2  setosa
3          4.7         3.2          1.3         0.2  setosa
4          4.6         3.1          1.5         0.2  setosa
5          5.0         3.6          1.4         0.2  setosa
6          5.4         3.9          1.7         0.4  setosa
> 
> # 第一列升序,然后是第三列升序
> head(arrange(iris,iris[,1],iris[,3]))
  Sepal.Length Sepal.Width Petal.Length Petal.Width Species
1          4.3         3.0          1.1         0.1  setosa
2          4.4         3.0          1.3         0.2  setosa
3          4.4         3.2          1.3         0.2  setosa
4          4.4         2.9          1.4         0.2  setosa
5          4.5         2.3          1.3         0.3  setosa
6          4.6         3.6          1.0         0.2  setosa
> 
> # 第一列升序,然后是第三列降序
> head(arrange(iris,iris[,1],-iris[,3]))
  Sepal.Length Sepal.Width Petal.Length Petal.Width Species
1          4.3         3.0          1.1         0.1  setosa
2          4.4         2.9          1.4         0.2  setosa
3          4.4         3.0          1.3         0.2  setosa
4          4.4         3.2          1.3         0.2  setosa
5          4.5         2.3          1.3         0.3  setosa
6          4.6         3.1          1.5         0.2  setosa

而且,arrange,可以直接输入列名,进行排序:

代码语言:javascript
复制
head(arrange(iris,Sepal.Length, -Petal.Length))

结果:

代码语言:javascript
复制
> head(arrange(iris,Sepal.Length, -Petal.Length))
  Sepal.Length Sepal.Width Petal.Length Petal.Width Species
1          4.3         3.0          1.1         0.1  setosa
2          4.4         2.9          1.4         0.2  setosa
3          4.4         3.0          1.3         0.2  setosa
4          4.4         3.2          1.3         0.2  setosa
5          4.5         2.3          1.3         0.3  setosa
6          4.6         3.1          1.5         0.2  setosa
大家好,我是邓飞,一个持续分享的农业数据分析师
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2022-02-09,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 育种数据分析之放飞自我 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 示例数据
  • 2. 使用R中自带函数order
  • 3. 使用dplyr的arrange
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档