第五章高級數據管理

#5高級數據管理

y<-data.frame(name=character(0),math=numeric(0),science=numeric(0),english=numeric(0))

mydata<-edit(y)

mydata

#5.2數值和字符處理函數

#5.2.1數學函數

#5.2.2統計函數

dada<-scale(mydata)#數據標準化

#5.2.3概率函數

set.seed()#設定隨機種子

runif(5)#生成服從正態分布的偽隨機數

#生成服從多元正太分布的數據

library(MASS)

options(digits=3)

set.seed(1234)

mean<-c(230.7,146.7,3.6)

sigma <- matrix(c(15360.8,6721.2,-47.1,

6721.2,4700.9,-16.5,

-47.1,-16.5,0.3),nrow=3,ncol=3)

mydata<-mvrnorm(500,mean,sigma)

mydata<-as.data.frame(mydata)

names(mydata)<-c("y","x1","x2")

dim(mydata)

head(mydata,n=10)

#5.2.4字符處理函數

#5.2.5其他實用函數

#5.2.6將函數應用于矩陣和數據框

#將函數應用于數據對象

a<-5

sqrt(a)

b<- c(1.243,5.654,2.99)

round(b)

c<-matrix(runif(12),nrow=3)

c

log(c)

mean(c)

#將一個函數應用到矩陣的所有行或列中

mydata<-matrix(rnorm(30),nrow=6)

mydata

apply(mydata,1,mean)#計算每行平均值

apply(mydata,2,mean)#計算每列平均值

apply(mydata,2,mean,trim=0.2)#計算每行平均值

#5.3數據處理難題的一套解決方案

options(digits=2)

setwd("e:/r")

library(xlsx)

student<-read.xlsx("student.xlsx",1)

student

roster<-data.frame(student,math,science,english,

stringAsFactor=FASLE)

z<-scale(#未完)


5-6

options(digits=2)

student<-c("J D","A W","B M",

"D J","J M","C C",

"R Y","G K","J E",

"M R")

math<-c(502,600,412,358,495,512,410,625,573,522)

science<-c(95,99,80,82,75,85,80,95,89,86)

english<-c(25,22,18,15,20,28,15,30,27,18)

roster<-data.frame(student,math,science,english,stringAsFactors=FALSE)

z<-scale(roster[,2:4])

score<-apply(z,1,mean)

roster<-cbind(roster,score)

y<-quantile(score,c(.8,.6,.4,.2))

roster$grade[score>=y[1]]<-"A"

roster$grade[score<y[1]&score>=y[2]]<-"B"

roster$grade[score<y[2]&score>=y[3]]<-"C"

roster$grade[score<y[3]&score>=y[4]]<-"D"

roster$grade[score<=y[4]]<-"F"

roster

class(roster$student)

roster$student<-as.character(roster$student)

name <- strsplit((roster$student)," ")#roster$student必須是字符變量才能用strsplit?

LN<-sapply(name, "[",2)

FN<-sapply(name, "[",1)

roster<-cbind(FN,LN,roster[,-1])

roster<-roster[order(LN,FN),]

roster



#5.4控制流

#5.4.1重復和循環

for( i in 1:10) print("H")

i<-10

while(i>0) {print("h");i<- i-1}

#5.4條件執行

#5.4.1 if-else

attach(roster)

if(is.character(math)) math<-as.factor(math)

if(!is.character(LN)) math<-as.factor(LN)else print("gggg")

#5.4.2 ifelse,二元,輸入輸出均為向量時

attach(roster)

ifelse(score>0.5,print("P"),print("f"))

outcome<-ifelse(score>0.5,"P","f")

5.4.3switch

feelings<-c("s","a")

for(i in feelings)

print(

switch(i,

h="iii",

a="tttt",

s="ccc",

a="ccc"))

#5.5用戶自編函數

mystats<-function(x,parametric=TRUE,print=FALSE){

if(parametric){center<-mean(x);spread<-sd(x)

}else{

center<-median(x);spread<-mad(x)

}

if(print&parametric){

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<-mystats(x,parametric=TRUE,print=FALSE)

#自編函數2

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 recognizede type\n"))}

mydate("long")

mydate("short")

mydate()

mydate("dvsdf")

5.6整合和重構

5.6.1轉置

cars<-mtcars[1:5,1:4]

cars

t(cars)

5.6.2整合數據

options(digits=3)

attach(mtcars)

mtcars

aggdata<-aggregate(mtcars,by=list(cyl,gear),FUN=mean,na.rm=TRUE)

aggdata

5.6.3reshape包融合和重鑄melt,dcast

library(reshape2)

md<-melt(mydata,id=c("id,time"))

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,156評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,401評論 3 415
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,069評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,873評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,635評論 6 408
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,128評論 1 323
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,203評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,365評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,881評論 1 334
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,733評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,935評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,475評論 5 358
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,172評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,582評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,821評論 1 282
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,595評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,908評論 2 372

推薦閱讀更多精彩內容