Chapter 05—Advanced data management(Part 2)
二. 控制流
statement:一个单独的R语句或者是一个复合的R语句;
cond:条件表达式,为TRUE或FALSE;
expr:数字或字符表达式;
seq:数字或字符串的顺序。
1.循环语句:for,while
(1)for(var in seq) statement
for(i in 1:10)
+ print("Hello R")
[1] "Hello R"
[1] "Hello R"
[1] "Hello R"
[1] "Hello R"
[1] "Hello R"
[1] "Hello R"
[1] "Hello R"
[1] "Hello R"
[1] "Hello R"
[1] "Hello R"
(2) while(cond) statement
> i<-10
> while(i>0) {print("Hello");i<-i-1}
[1] "Hello"
[1] "Hello"
[1] "Hello"
[1] "Hello"
[1] "Hello"
[1] "Hello"
[1] "Hello"
[1] "Hello"
[1] "Hello"
[1] "Hello"
2. 条件语句:if-else, ifelse, switch
(1) if-else
if(cond) statement
if(cond) statement1 else statement2
> grade<-"wang shen wen"
> grade
[1] "wang shen wen"
> if(is.character(grade)) grade<-as.factor(grade)
> grade
[1] wang shen wen
Levels: wang shen wen
> if(!is.factor(grade))
+ grade<-as.factor(grade) else
+ print("Grade already is a factor")
[1] "Grade already is a factor"
(2)ifelse
ifelse(cond,statement1,statement2)
·如果cond为TRUE,则执行ststement1;若cond为FALSE,则执行statement2.
score<-0.3
> ifelse(score>0.5,print("Passed"),print("Failed"))
[1] "Failed"
[1] "Failed"
>
> outcome<-ifelse(score>0.5,"passed","failed")
> outcome
[1] "failed"
print("Failed"):会打印两次Failed,因为第一次是Failed这个短语,第二次是print()函数自身。
(3)switch
switch(expr,...)
feelings<-c("sad","afraid")
> for(i in feelings)
+ print(
+ switch(i,
+ happy="I am gald you are happy",
+ afraid="There is nothing to fear",
+ sad="Cheer up",
+ angry="Calm down now"
+ )
+ )
[1] "Cheer up"
[1] "There is nothing to fear"
三. 用户自定义函数(user-written functions)
myfunction<-function(arg1,arg2,...){
statements
return(object)
}
例10:
定义一个函数mystat,选择参数(parameter),即平均值(mean)和方差(standard deviation);
或选择非参数(nonparametric),即中位数(median)和绝对中位差(median absolute deviation)。
> mystat<-function(x,parametric=TRUE,print=FALSE){
+ if(parametric){
+ center<-mean(x); spread<-sd(x)
+ } else{
+ center<-median(x); spread<-mad(x)
+ }
+ if(print¶metric){
+ cat("Mean=",center,"\n","SD",spread,"\n")
+ } else{
+ cat("Median=",center,"\n","MAD",spread,"\n")
+ }
+ result<-list(center=center,spread=spread)
+ return(result)
+ }
>
> set.seed(1234)
> x<-rnorm(500)
>
> y<-mystat(x)
Median= 0.0018
MAD 1
> y<-mystat(x,parametric=FALSE,print=TRUE)
Median= -0.021
MAD 1
例11:让用户选择输出日期的格式。
mydate<-function(type="long"){
+ switch(type,
+ long = format(Sys.time(),"%A %B %d %Y"),
+ short = format(Sys.time(),"%m-%d-%y"),
+ cat(type,"is not a recognized type\n")
+ )
+ }
>
> mydate("long")
[1] "星期四 八月 01 2013"
> mydate("short")
[1] "08-01-13"
> mydate("medium")
medium is not a recognized type
四. 聚合(aggregation)和重组(restructuring)
1. 反置(transpose)
使用t()函数反置一个矩阵或一个数据集,即行列的变量交换。
例12:
> cars<-mtcars[1:5,1:4]
> cars
mpg cyl disp hp
Mazda RX4 21 6 160 110
Mazda RX4 Wag 21 6 160 110
Datsun 710 23 4 108 93
Hornet 4 Drive 21 6 258 110
Hornet Sportabout 19 8 360 175
> t(cars)
Mazda RX4 Mazda RX4 Wag Datsun 710 Hornet 4 Drive Hornet Sportabout
mpg 21 21 23 21 19
cyl 6 6 4 6 8
disp 160 160 108 258 360
hp 110 110 93 110 175
2. 聚合(aggregating)
aggregate(x,by,FUN)
·x:初始数据集;
·by:创建新观测值(observations)的变量表(lists of variables);
·FUN:使用新的观测值来,计算总的统计数据值。
例13:
options(digits=3)
> attach(mtcars)
> aggdata<-aggregate(mtcars,by=list(cyl,gear),FUN=mean,na.rm=TRUE)
> aggdata
Group.1 Group.2 mpg cyl disp hp drat wt qsec vs am gear carb
1 4 3 21.5 4 120 97 3.70 2.46 20.0 1.0 0.00 3 1.00
2 6 3 19.8 6 242 108 2.92 3.34 19.8 1.0 0.00 3 1.00
3 8 3 15.1 8 358 194 3.12 4.10 17.1 0.0 0.00 3 3.08
4 4 4 26.9 4 103 76 4.11 2.38 19.6 1.0 0.75 4 1.50
5 6 4 19.8 6 164 116 3.91 3.09 17.7 0.5 0.50 4 4.00
6 4 5 28.2 4 108 102 4.10 1.83 16.8 0.5 1.00 5 2.00
7 6 5 19.7 6 145 175 3.62 2.77 15.5 0.0 1.00 5 6.00
8 8 5 15.4 8 326 300 3.88 3.37 14.6 0.0 1.00 5 6.00
3. reshape包
在数据集的重构和聚合方面,reshape包是非常有用的。但是需要先安装,再使用,因为不是R中的基础包。
install.packages("reshape")
(1)“melt” data:是每一行是一个特别的ID变量组合(a unique ID-variable combination).
melt()函数:对一个数据集(dataset),把该数据集重构成另一种形式,每一个测量过的变量(measured variables)在其自身那行中,都有一个ID变量特别的指示着该变量。
例14:

> library(reshape)
载入需要的程辑包:plyr 载入程辑包:‘reshape’ 下列对象被屏蔽了from ‘package:plyr’: rename, round_any > md<-melt(mydata,id=(c("id","time")))
Error: id variables not found in data: id, time
> id<-c(1,1,2,2)
> time<-c(1,2,1,2)
> x1<-c(5,3,6,2)
> x2<-c(6,5,1,4)
>
> mydata<-data.frame(id,time,x1,x2)
> md<-melt(mydata,id=(c("id","time")))
> md
id time variable value
1 1 1 x1 5
2 1 2 x1 3
3 2 1 x1 6
4 2 2 x1 2
5 1 1 x2 6
6 1 2 x2 5
7 2 1 x2 1
8 2 2 x2 4
(2)“cast” the melted data:使之成为想要的形状。在cast过程中,使用函数对数据进行聚合。
cast()函数:处理melted 的数据时使用,使用一个公式(formula),提供一个可选的函数(function),去聚合函数。
newdata<-cast(md,formula,FUN)
·md:melted data;
·formula:描述期待的最终结果;
其形式为:rowvar1+rowvar2+...+colvar1+colvar2+...
rowvar1+rowvar2+...定义决定行的变量的集合;
colvar1+colvar2+...定义决定列的变量的集合。
·FUN(可选):聚合函数。
Chapter 05—Advanced data management(Part 2)的更多相关文章
- Chapter 05—Advanced data management(Part 1)
一. R的数学函数,统计函数及字符处理函数 例01:一道实际应用题 一组学生其数学,科学和英语的成绩如下表: 任务:根据成绩,决定对每个学生的单独指导: 前20%的学生的成绩为A,次之为B,以此类推: ...
- Chapter 04—Basic Data Management
1. 创建新的变量 variable<-expression expression:包含一组大量的操作符和函数.常用的算术操作符如下表: 例1:根据已知变量,创建新变量的三种途径 > my ...
- MySQL vs. MongoDB: Choosing a Data Management Solution
原文地址:http://www.javacodegeeks.com/2015/07/mysql-vs-mongodb.html 1. Introduction It would be fair to ...
- 场景3 Data Management
场景3 Data Management 数据管理 性能优化 OLTP OLAP 物化视图 :表的快照 传输表空间 :异构平台的数据迁移 星型转换 :事实表 OLTP : 在线事务处理 1. trans ...
- Advanced Data Structures
Advanced Data Structures Advanced Data Structures
- [Windows Azure] Data Management and Business Analytics
http://www.windowsazure.com/en-us/develop/net/fundamentals/cloud-storage/ Managing and analyzing dat ...
- Data Management Technology(1) -- Introduction
1.Database concepts (1)Data & Information Information Is any kind of event that affects the stat ...
- Data Management and Data Management Tools
Data Management ObjectivesBy the end o this module, you should understand the fundamentals of data m ...
- Building Applications with Force.com and VisualForce(Dev401)(十七):Data Management: Data management Tools
ev401-018:Data Management: Data management ToolsModule Objectives1.List objects exposed in the impor ...
随机推荐
- 提高首屏页面加载速度,解决vue-cli打包后单个文件过大的问题
本教程是针对vue-cli3以上的版本,其实原理都大同小异,这个demo为vue-cli直接创建的项目,并在main.js中引入了echart.element-ui.lodash 首先看demo打包后 ...
- Django学习day1——Django的简单介绍
1.了解Web基本的开发 使用Python开发Web,最简单,原始和直接的办法是使用CGI标准现在从应用角度解释它是如何工作: 首先做一个Python脚本,输出HTML代码,然后保存成.cgi扩展名的 ...
- [考试反思]0921csp-s模拟测试49:困顿
太弱.还是太弱. 拉不开分差,离第一机房分数线估计还是300多分. 但是,还是要骂:XX出题人. 部分分非常少且没有意义,T1基本只有0/纯暴力20/100三个档, T2正解是n2但是n3一分不给,还 ...
- Python实现日志文件写入或者打印--类似于Java的Log4j
开发过Java的应该都知道Log4j的重要性,尤其是在开发测试中,能够让开发和测试人员方便找的bug,Python也有和Log4j相同功能的库那就是logging库,其功能非常强大,在开发测试中很方便 ...
- .NET手撸绘制TypeScript类图——上篇
.NET手撸绘制TypeScript类图--上篇 近年来随着交互界面的精细化,TypeScript越来越流行,前端的设计也越来复杂,而类图正是用简单的箭头和方块,反映对象与对象之间关系/依赖的好方式. ...
- 如何使用24行JavaScript代码实现Redux
作者:Yazeed Bzadough 译者:小维FE 原文:freecodecamp 为了保证文章的可读性,本文采用意译而非直译. 90%的规约,10%的库. Redux是迄今为止创建的最重要的Jav ...
- 监听器以及在监听类里面获得bean的方法
1实现HttpSessionListener和ServletContextListener,2个接口 2然后在contextInitialized初始化方法里面: ServletContext app ...
- java 实现一个死锁
/** * 死锁:两个或多个线程在执行过程中,相互争夺资源而造成的一种互相等待的现象 * 实现一个死锁 * <p> * <p> * 查看死锁 * 1. 在当前类的文件夹下,打开 ...
- nginx 根据不同url转发请求对应tomcat容器
根据前端请求的url,nginx转发到指定的tomcat容器 原理如图: 现在我们有2个tomcat,一个tomcat的端口为9001,另一个tomcat的端口为9002 1.找到nginx的配置文件 ...
- thinkphp 比RBAC更好的权限认证方式(Auth类认证)
Auth 类已经在ThinkPHP代码仓库中存在很久了,但是因为一直没有出过它的教程, 很少人知道它, 它其实比RBAC更方便 . RBAC是按节点进行认证的,如果要控制比节点更细的权限就有点困难了, ...