这篇文章主要介绍了R语言-使用ifelse进行数据分组,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
数据分组,根据数据分析对象的特征,按照一定的数值指标,把数据分析对象划分为不同的区间部分来研究,以揭示内在的联系和规律性;
在R中,我们常用ifelse函数来进行数据的分组,跟excel中的if函数是同一种用法。
ifelse(condition,TRUE,FALSE)
> data <- read.table('1.csv', sep='|', header=TRUE);
>
> level <- ifelse(
+ data$cost<=20, "(0,20]",
+ ifelse(
+ data$cost<=40, "(20,40]",
+ ifelse(
+ data$cost<=60, "(40,60]",
+ ifelse(
+ data$cost<=80, "(60,80]",
+ ifelse(
+ data$cost<=100, "(80,100]", "(100,+)"
+ )
+ )
+ )
+ )
+ )
> level
[1] "(0,20]" "(0,20]" "(60,80]" "(0,20]" "(80,100]" "(0,20]" "(80,100]"
[8] "(60,80]" "(0,20]" "(40,60]" "(20,40]" "(0,20]" "(60,80]" "(80,100]"
[15] "(0,20]"
> newData <- data.frame(data, level)
数据分组后的结果:
补充:R语言----对数据进行分类汇总(GROUP_BY使用)
library(dplyr) ###加载dplyr模块
A<-read.csv("f:\\TEST\\TDD.csv") ####加载数据
D=data.frame(A) #####
A1<-group_by(D,Date_ID) ####分组项
A2<-summarise(A1,cells=n(), ####统计个数
RRC_chenggongshu=sum(RRC_chenggongshu),
RRC_QINGQIUSHU=sum(RRC_qingqiushu),
成功率=round(sum(RRC_chenggongshu)/sum(RRC_qingqiushu)*100,3),
ERABCQI1_qingqiushu=sum(ERABCQI1_qingqiushu)
)
write.csv(A2,"output.csv", row.names = FALSE)'去掉行名。 这可以在写入文件时使用附加参数删除。
执行结果:
以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程学习网。如有错误或未考虑完全的地方,望不吝赐教。
沃梦达教程
本文标题为:R语言-使用ifelse进行数据分组
猜你喜欢
- Ruby 迭代器知识汇总 2023-07-23
- R语言-如何切换科学计数法和更换小数点位数 2022-11-23
- Ruby on Rails在Ping ++ 平台实现支付 2023-07-22
- R语言关于二项分布知识点总结 2022-11-30
- Go Web开发进阶实战(gin框架) 2023-09-06
- 汇编语言程序设计之根据输入改变屏幕颜色的代码 2023-07-06
- R语言绘图数据可视化pie chart饼图 2022-12-10
- Ruby的字符串与数组求最大值的相关问题讨论 2023-07-22
- Golang http.Client设置超时 2023-09-05
- Swift超详细讲解指针 2023-07-08