學(xué)習(xí)小組Day6筆記——山川石

學(xué)習(xí)R包

R包的安裝和加載

  • 鏡像設(shè)置
  1. 鼠標點擊設(shè)置
    在RStudio程序設(shè)置中點擊Tools-Packages荔燎,設(shè)置CRAN鏡像徘键,可以通過options()$repos來檢驗绍哎。
  2. 使用代碼設(shè)置
options("repos" = c(CRAN="https://mirrors.tuna.tsinghua.edu.cn/CRAN/")) #清華源
options(BioC_mirror="https://mirrors.ustc.edu.cn/bioc/") #中科大源

可以通過options()$BioC_mirror來檢驗赃泡。

  1. 使用R的配置文件.Rprofile
    用file.edit()來編輯文件:
file.edit('~/.Rprofile')

再添加

options("repos" = c(CRAN="https://mirrors.tuna.tsinghua.edu.cn/CRAN/")) 
options(BioC_mirror="https://mirrors.ustc.edu.cn/bioc/") 

保存重啟后寒波,再運行options()$reposoptions()$BioC_mirror檢驗。

  • 安裝
install.packages(“包”) #安裝包存在于CRAN網(wǎng)站
BiocManager::install(“包”) #安裝包存在于biocductor
  • 加載
    下面兩個命令均可升熊。
library(包)
require(包)

例:安裝并加載dplyr包

options("repos" = c(CRAN="https://mirrors.tuna.tsinghua.edu.cn/CRAN/")) 
options(BioC_mirror="https://mirrors.ustc.edu.cn/bioc/") 
install.packages("dplyr")
library(dplyr)

dplyr基礎(chǔ)函數(shù)

示例數(shù)據(jù)使用內(nèi)置數(shù)據(jù)集iris的簡化版俄烁。
test <- iris[c(1:2,51:52,101:102),]
運行結(jié)果如下:

    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
51           7.0         3.2          4.7         1.4 versicolor
52           6.4         3.2          4.5         1.5 versicolor
101          6.3         3.3          6.0         2.5  virginica
102          5.8         2.7          5.1         1.9  virginica

1. mutate() #新增列
mutate(test, new = Sepal.Length * Sepal.Width
運行結(jié)果如下:

  Sepal.Length Sepal.Width Petal.Length Petal.Width    Species   new
1          5.1         3.5          1.4         0.2     setosa 17.85
2          4.9         3.0          1.4         0.2     setosa 14.70
3          7.0         3.2          4.7         1.4 versicolor 22.40
4          6.4         3.2          4.5         1.5 versicolor 20.48
5          6.3         3.3          6.0         2.5  virginica 20.79
6          5.8         2.7          5.1         1.9  virginica 15.66

2. select() #按列篩選

  • 按列號篩選
    (1)篩選單列select(test,1)
    Sepal.Length
1            5.1
2            4.9
51           7.0
52           6.4
101          6.3
102          5.8

(2)篩選多列select(test,c(1,5)) #篩選第一列及第五列

    Sepal.Length    Species
1            5.1     setosa
2            4.9     setosa
51           7.0 versicolor
52           6.4 versicolor
101          6.3  virginica
102          5.8  virginica
  • 按列名篩選
    (1)直接輸入列名篩選
    select(test, Petal.Length, Petal.Width)
    (2)在創(chuàng)建的包含列名的新變量中篩選
vars <- c("Petal.Length", "Petal.Width") #創(chuàng)建包含要篩選列名的變量
select(test, one_of(vars)) #one_of為聲明選擇對象

兩種方式的結(jié)果如下:

    Petal.Length Petal.Width
1            1.4         0.2
2            1.4         0.2
51           4.7         1.4
52           4.5         1.5
101          6.0         2.5
102          5.1         1.9

3. filter() #篩選行
(1)用行名直接篩選
filter(test, Species == "setosa")
結(jié)果如下:

  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

(2)對篩選的行名做進一步限制
filter(test, Species == "setosa"&Sepal.Length > 5 )
結(jié)果如下:

  Sepal.Length Sepal.Width Petal.Length Petal.Width Species
1          5.1         3.5          1.4         0.2  setosa

(3)篩選不同的行
filter(test, Species %in% c("setosa","versicolor"))
結(jié)果如下:

  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          7.0         3.2          4.7         1.4 versicolor
4          6.4         3.2          4.5         1.5 versicolor

4. arrange() #對表格排序
arrange(test, Sepal.Length)#默認從小到大排序

  Sepal.Length Sepal.Width Petal.Length Petal.Width    Species
1          4.9         3.0          1.4         0.2     setosa
2          5.1         3.5          1.4         0.2     setosa
3          5.8         2.7          5.1         1.9  virginica
4          6.3         3.3          6.0         2.5  virginica
5          6.4         3.2          4.5         1.5 versicolor
6          7.0         3.2          4.7         1.4 versicolor

arrange(test, desc(Sepal.Length))#用desc從大到小排序

Sepal.Length Sepal.Width Petal.Length Petal.Width    Species
1          7.0         3.2          4.7         1.4 versicolor
2          6.4         3.2          4.5         1.5 versicolor
3          6.3         3.3          6.0         2.5  virginica
4          5.8         2.7          5.1         1.9  virginica
5          5.1         3.5          1.4         0.2     setosa
6          4.9         3.0          1.4         0.2     setosa

5. summarise() #數(shù)據(jù)匯總

> summarise(test, mean(Sepal.Length), sd(Sepal.Length))
#對指定行計算平均值和標準差
  mean(Sepal.Length) sd(Sepal.Length)
1           5.916667        0.8084965
######################
> group_by(test, Species)
#按照Species分組
# A tibble: 6 x 5
# Groups:   Species [3]
  Sepal.Length Sepal.Width Petal.Length Petal.Width Species   
*        <dbl>       <dbl>        <dbl>       <dbl> <fct>     
1          5.1         3.5          1.4         0.2 setosa    
2          4.9         3            1.4         0.2 setosa    
3          7           3.2          4.7         1.4 versicolor
4          6.4         3.2          4.5         1.5 versicolor
5          6.3         3.3          6           2.5 virginica 
6          5.8         2.7          5.1         1.9 virginica 
##########################
> summarise(group_by(test, Species),mean(Sepal.Length), sd(Sepal.Length))
#按species分組后再計算每組Sepal.Length的平均值和標準差
# A tibble: 3 x 3
  Species    `mean(Sepal.Length)` `sd(Sepal.Length)`
  <fct>                     <dbl>              <dbl>
1 setosa                     5                 0.141
2 versicolor                 6.7               0.424
3 virginica                  6.05              0.354

dplyr實用技能

1. 管道操作 %>%
test %>% group_by(Species) %>% summarise(mean(Sepal.Length), sd(Sepal.Length))#管道從左向右進行

結(jié)果如下:

# A tibble: 3 x 3
  Species    `mean(Sepal.Length)` `sd(Sepal.Length)`
  <fct>                     <dbl>              <dbl>
1 setosa                     5                 0.141
2 versicolor                 6.7               0.424
3 virginica                  6.05              0.354

2. count統(tǒng)計某列的unique值
count(test,Species)
結(jié)果如下:

# A tibble: 3 x 2
 Species        n
 <fct>      <int>
1 setosa         2
2 versicolor     2
3 virginica      2

dplyr處理關(guān)系數(shù)據(jù)

將兩個表連接,注意不要引入factor级野。
以下兩圖來自“各種join一目了然——CSDN(CalmReason)”

數(shù)據(jù)關(guān)系

數(shù)據(jù)關(guān)系

創(chuàng)建表格

options(stringsAsFactors = F) #不引入factor
test1 <- data.frame(x = c('b','e','f','x'), 
                    z = c("A","B","C",'D'),
                    stringsAsFactors = F)
test2 <- data.frame(x = c('a','b','c','d','e','f'), 
                    y = c(1,2,3,4,5,6),
                    stringsAsFactors = F)
test1
  x z
1 b A
2 e B
3 f C
4 x D

test2 
  x y
1 a 1
2 b 2
3 c 3
4 d 4
5 e 5
6 f 6
  • 內(nèi)連接inner_join
inner_join(test1, test2, by = "x")
  x z y
1 b A 2
2 e B 5
3 f C 6
  • 左連接left_join页屠,意為以左邊的表格為準,右表與選擇連接的列名一致的填寫右表數(shù)據(jù)蓖柔,不一致的為NA辰企。
left_join(test1, test2, by = 'x')
  x z  y
1 b A  2
2 e B  5
3 f C  6
4 x D NA

left_join(test2, test1, by = 'x')
  x y    z
1 a 1 <NA>
2 b 2    A
3 c 3 <NA>
4 d 4 <NA>
5 e 5    B
6 f 6    C
  • 右連接right_join,與左連接類似况鸣,左連接的左右兩表互換位置得到的結(jié)果與右連接一致牢贸。
right_join(test1, test2, by = 'x')
  x    z y
1 a <NA> 1
2 b    A 2
3 c <NA> 3
4 d <NA> 4
5 e    B 5
6 f    C 6
  • 全連接full_join,取并集镐捧,缺失數(shù)據(jù)為NA
full_join( test1, test2, by = 'x')
  x    z  y
1 b    A  2
2 e    B  5
3 f    C  6
4 x    D NA
5 a <NA>  1
6 c <NA>  3
7 d <NA>  4
  • 半連接semi_join潜索,返回能夠與y表匹配的x表所有記錄semi_join
semi_join(x = test1, y = test2, by = 'x')
  x z
1 b A
2 e B
3 f C
  • 反連接anti_join臭增,返回無法與y表匹配的x表的所記錄anti_join
anti_join(x = test2, y = test1, by = 'x')
  x y
1 a 1
2 c 3
3 d 4
  • 簡單合并
    創(chuàng)建表格:
> test1 <- data.frame(x = c(1,2,3,4), y = c(10,20,30,40))
> test1
  x  y
1 1 10
2 2 20
3 3 30
4 4 40
> test2 <- data.frame(x = c(5,6), y = c(50,60))
> test2
  x  y
1 5 50
2 6 60
> test3 <- data.frame(z = c(100,200,300,400))
> test3
    z
1 100
2 200
3 300
4 400

合并表格

> bind_rows(test1, test2) #合并行,需要兩個表格列數(shù)相同
  x  y
1 1 10
2 2 20
3 3 30
4 4 40
5 5 50
6 6 60
> bind_cols(test1, test3) #合并列竹习,需要兩個表格行數(shù)相同
  x  y   z
1 1 10 100
2 2 20 200
3 3 30 300
4 4 40 400

如果行數(shù)或列數(shù)不相同會報錯誊抛。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市整陌,隨后出現(xiàn)的幾起案子拗窃,更是在濱河造成了極大的恐慌,老刑警劉巖蔓榄,帶你破解...
    沈念sama閱讀 216,372評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件并炮,死亡現(xiàn)場離奇詭異,居然都是意外死亡甥郑,警方通過查閱死者的電腦和手機逃魄,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來澜搅,“玉大人伍俘,你說我怎么就攤上這事∶闾桑” “怎么了癌瘾?”我有些...
    開封第一講書人閱讀 162,415評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長饵溅。 經(jīng)常有香客問我妨退,道長,這世上最難降的妖魔是什么蜕企? 我笑而不...
    開封第一講書人閱讀 58,157評論 1 292
  • 正文 為了忘掉前任咬荷,我火速辦了婚禮,結(jié)果婚禮上轻掩,老公的妹妹穿的比我還像新娘幸乒。我一直安慰自己,他們只是感情好唇牧,可當我...
    茶點故事閱讀 67,171評論 6 388
  • 文/花漫 我一把揭開白布罕扎。 她就那樣靜靜地躺著,像睡著了一般丐重。 火紅的嫁衣襯著肌膚如雪腔召。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,125評論 1 297
  • 那天弥臼,我揣著相機與錄音宴咧,去河邊找鬼。 笑死径缅,一個胖子當著我的面吹牛掺栅,可吹牛的內(nèi)容都是我干的烙肺。 我是一名探鬼主播,決...
    沈念sama閱讀 40,028評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼氧卧,長吁一口氣:“原來是場噩夢啊……” “哼桃笙!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起沙绝,我...
    開封第一講書人閱讀 38,887評論 0 274
  • 序言:老撾萬榮一對情侶失蹤搏明,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后闪檬,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體星著,經(jīng)...
    沈念sama閱讀 45,310評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,533評論 2 332
  • 正文 我和宋清朗相戀三年粗悯,在試婚紗的時候發(fā)現(xiàn)自己被綠了虚循。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,690評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡样傍,死狀恐怖横缔,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情衫哥,我是刑警寧澤茎刚,帶...
    沈念sama閱讀 35,411評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站撤逢,受9級特大地震影響膛锭,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜蚊荣,卻給世界環(huán)境...
    茶點故事閱讀 41,004評論 3 325
  • 文/蒙蒙 一泉沾、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧妇押,春花似錦、人聲如沸姓迅。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽丁存。三九已至肩杈,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間解寝,已是汗流浹背扩然。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評論 1 268
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留聋伦,地道東北人夫偶。 一個月前我還...
    沈念sama閱讀 47,693評論 2 368
  • 正文 我出身青樓界睁,卻偏偏與公主長得像,于是被迫代替她去往敵國和親兵拢。 傳聞我的和親對象是個殘疾皇子翻斟,可洞房花燭夜當晚...
    茶點故事閱讀 44,577評論 2 353

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