第16章 使用purrr實(shí)現(xiàn)迭代

16.1 簡介

減少重復(fù)代碼的方式一個(gè)是前面所提及的function功能一個(gè)是進(jìn)行迭代計(jì)算
關(guān)于減少重復(fù)代碼的好處我就不細(xì)談了焦影,書上已經(jīng)寫得非常清楚了。

  • 明意圖
  • 便修改
  • 少bug
    本章將使用命令編程中的for循環(huán)和while循環(huán)對代碼進(jìn)行修改和提取玫膀。

for循環(huán)

for循環(huán)主要應(yīng)用的索引
這個(gè)索引我認(rèn)為就是位置矛缨,就跟目錄頁的書頁號一樣!

每個(gè) for 循環(huán)都包括 3 個(gè)部分帖旨。

  • 輸出:output <- vector("double", length(x)) 這就是先給你輸出的結(jié)果分配一個(gè)倉庫箕昭,等一會結(jié)果出來了就直接懟進(jìn)去!當(dāng)然了倉庫類型也不同 大小也不同解阅。當(dāng)然你也可以不指定倉庫的類型落竹。

  • 序列:i in seq_along(df) 這就是有多少個(gè)要進(jìn)行加工的貨啊货抄!

  • 循環(huán)體 output[] <- median(df[])就是加工的過程是啥呀述召!出來的東西要進(jìn)倉庫了!

帶著做一個(gè)練習(xí)題吧
Compute the mean of every column in mtcars

str(mtcars)
'data.frame':   32 obs. of  11 variables:
 $ mpg : num  21 21 22.8 21.4 18.7 18.1 14.3 24.4 22.8 19.2 ...
 $ cyl : num  6 6 4 6 8 6 8 4 4 6 ...
 $ disp: num  160 160 108 258 360 ...
 $ hp  : num  110 110 93 110 175 105 245 62 95 123 ...
 $ drat: num  3.9 3.9 3.85 3.08 3.15 2.76 3.21 3.69 3.92 3.92 ...
 $ wt  : num  2.62 2.88 2.32 3.21 3.44 ...
 $ qsec: num  16.5 17 18.6 19.4 17 ...
 $ vs  : num  0 0 1 1 0 1 0 1 1 1 ...
 $ am  : num  1 1 1 0 0 0 0 0 0 0 ...
 $ gear: num  4 4 4 3 3 3 3 4 4 4 ...
 $ carb: num  4 4 1 1 2 1 4 2 2 4 ...

head(mtcars)
                   mpg cyl disp  hp drat    wt  qsec
Mazda RX4         21.0   6  160 110 3.90 2.620 16.46
Mazda RX4 Wag     21.0   6  160 110 3.90 2.875 17.02
Datsun 710        22.8   4  108  93 3.85 2.320 18.61
Hornet 4 Drive    21.4   6  258 110 3.08 3.215 19.44
Hornet Sportabout 18.7   8  360 175 3.15 3.440 17.02
Valiant           18.1   6  225 105 2.76 3.460 20.22
                  vs am gear carb
Mazda RX4          0  1    4    4
Mazda RX4 Wag      0  1    4    4
Datsun 710         1  1    4    1
Hornet 4 Drive     1  0    3    1
Hornet Sportabout  0  0    3    2
Valiant            1  0    3    1

output <- vector("double", ncol(mtcars))
names(output) <- names(mtcars)
for (i in names(mtcars)) {**這塊要注意 如果你用seq_along返回的是帶字符型數(shù)值的數(shù)據(jù) 不能計(jì)算哦蟹地!**
  output[i] <- mean(mtcars[[i]])
}
output
# 

for循環(huán)變體
修改現(xiàn)有對象(觀測值)

df <- tibble(
  a = rnorm(10),
  b = rnorm(10),
  c = rnorm(10),
  d = rnorm(10)
)
rescale01 <- function(x) {
  rng <- range(x, na.rm = TRUE)
  (x - rng[1]) / (rng[2] - rng[1])
}

df$a <- rescale01(df$a)
df$b <- rescale01(df$b)
df$c <- rescale01(df$c)
df$d <- rescale01(df$d)

for (i in seq_along(df)) {
  df[[i]] <- rescale01(df[[i]])
}

練習(xí)1中讀取CSV文件 在批量提取測序數(shù)據(jù)的相同基因的表達(dá)值時(shí)用的到

df <- vector("list", length(files))
for (fname in seq_along(files)) {
  df[[i]] <- read_csv(files[[i]])
}
df <- bind_rows(df)

for循環(huán)與函數(shù)式編程

重點(diǎn)說一下apply()积暖,lapply(),tapply()等函數(shù)

  • Apply Functions Over Array Margins Returns a vector or array or list of values obtained by applying a function to margins of an array or matrix.
apply(df,2,mean)  #其中的2表示列 具體解釋如下:給出將應(yīng)用該函數(shù)的下標(biāo)的向量怪与。 例如夺刑,矩陣1表示行,2表示列分别,c(1,2)表示行和列性誉。 其中X命名為dimnames,它可以是選擇維名稱的字符向量茎杂。
等價(jià)于
 output <- vector("double", length(df))
  for (i in seq_along(df)) {
    output[i] <- mean(df[[i]])
  }
  output
  • lapply返回一個(gè)與X相同長度的列表错览,其中每個(gè)元素都是將FUN應(yīng)用于X的相應(yīng)元素的結(jié)果。
> lapply(df, mean)
$`a`
[1] -0.4432281

$b
[1] -0.1124617

$c
[1] 0.2448539

$d
[1] -0.03413569
class(lapply(df,mean))
[1] "list"
  • sapply是一個(gè)用戶友好的版本和lapply的包裝器煌往,默認(rèn)情況下通過應(yīng)用
class(sapply(x, mean))
  • simplify2array()返回一個(gè)向量倾哺,矩陣,或者刽脖,如果需要羞海,則更新一個(gè)數(shù)組(如果合適)。 sapply(x曲管,f却邓,simplify = FALSE,USE.NAMES = FALSE)與lapply(x院水,f)相同腊徙。

  • vapply類似于sapply简十,但具有預(yù)先指定類型的返回值,因此它可以更安全(有時(shí)更快)使用撬腾。

  • replicate是一個(gè)常用的sapply包裝器螟蝙,用于重復(fù)評估表達(dá)式(通常涉及隨機(jī)數(shù)生成)。

  • simplify2array()是當(dāng)simple不為false并且從mapply()類似地調(diào)用時(shí)從sapply()調(diào)用的實(shí)用程序民傻。

https://www.zhihu.com/question/39843392

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末胰默,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子漓踢,更是在濱河造成了極大的恐慌牵署,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,695評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件喧半,死亡現(xiàn)場離奇詭異奴迅,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)薯酝,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,569評論 3 399
  • 文/潘曉璐 我一進(jìn)店門半沽,熙熙樓的掌柜王于貴愁眉苦臉地迎上來爽柒,“玉大人吴菠,你說我怎么就攤上這事『拼澹” “怎么了做葵?”我有些...
    開封第一講書人閱讀 168,130評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長心墅。 經(jīng)常有香客問我酿矢,道長,這世上最難降的妖魔是什么怎燥? 我笑而不...
    開封第一講書人閱讀 59,648評論 1 297
  • 正文 為了忘掉前任瘫筐,我火速辦了婚禮,結(jié)果婚禮上铐姚,老公的妹妹穿的比我還像新娘策肝。我一直安慰自己,他們只是感情好隐绵,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,655評論 6 397
  • 文/花漫 我一把揭開白布之众。 她就那樣靜靜地躺著,像睡著了一般依许。 火紅的嫁衣襯著肌膚如雪棺禾。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,268評論 1 309
  • 那天峭跳,我揣著相機(jī)與錄音膘婶,去河邊找鬼缺前。 笑死,一個(gè)胖子當(dāng)著我的面吹牛竣付,可吹牛的內(nèi)容都是我干的诡延。 我是一名探鬼主播,決...
    沈念sama閱讀 40,835評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼古胆,長吁一口氣:“原來是場噩夢啊……” “哼肆良!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起逸绎,我...
    開封第一講書人閱讀 39,740評論 0 276
  • 序言:老撾萬榮一對情侶失蹤惹恃,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后棺牧,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體巫糙,經(jīng)...
    沈念sama閱讀 46,286評論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,375評論 3 340
  • 正文 我和宋清朗相戀三年颊乘,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了参淹。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,505評論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡乏悄,死狀恐怖浙值,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情檩小,我是刑警寧澤开呐,帶...
    沈念sama閱讀 36,185評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站规求,受9級特大地震影響筐付,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜阻肿,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,873評論 3 333
  • 文/蒙蒙 一瓦戚、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧丛塌,春花似錦较解、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,357評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至乍楚,卻和暖如春当编,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背徒溪。 一陣腳步聲響...
    開封第一講書人閱讀 33,466評論 1 272
  • 我被黑心中介騙來泰國打工忿偷, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留金顿,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,921評論 3 376
  • 正文 我出身青樓鲤桥,卻偏偏與公主長得像揍拆,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子茶凳,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,515評論 2 359

推薦閱讀更多精彩內(nèi)容

  • pyspark.sql模塊 模塊上下文 Spark SQL和DataFrames的重要類: pyspark.sql...
    mpro閱讀 9,464評論 0 13
  • 青春是一首歌嫂拴,總是要由男生、女生共同來演奏贮喧,才能奏出最清脆的樂意筒狠。 青春是一道風(fēng)景線,總是要由男生箱沦、女...
    趙毅婷閱讀 532評論 1 1
  • 時(shí)光啊谓形,你太快了 我趕不上準(zhǔn)備 時(shí)光啊灶伊,你太快了 我等不了迷惘 時(shí)光啊,你太快了 我來不及犯錯(cuò) 時(shí)光啊寒跳,你太快了 ...
    侑菲閱讀 156評論 1 0