R語言基礎之第二部分 操縱數(shù)據(jù)/取子集

R語言基礎之第部分:操縱數(shù)據(jù)取子集

2.1 構建子集
[ ]:提取一個or多個類型相同的元素
[[ ]]:從列表或數(shù)據(jù)框中提取元素
$ :按名字從列表or數(shù)據(jù)框中提取元素

2.11 取向量子集

x = 1:10
x[x>5]          #取x中小于5的元素
x[x>5  & x<7]   #取x中小于7大于5的元素
x[x<5  |  x>8]   #取x中小于5 或者 大于8的元素
y = 1:4
names(y) = c("a","b","c","d")
y
a b c d 
1 2 3 4 
y[2]   #直接取第2個元素
y["b"]    #取名稱是b的元素肌稻,有時候我們只記得名稱

2.12 取矩陣子集

> x = matrix( 1:6, nrow = 2, ncol = 3)
> x
     [,1] [,2] [,3]
[1,]    1    3    5
[2,]    2    4    6
> x[1,2]   #取矩陣x的1行2列的元素
[1] 3
> x[1,]   #取矩陣x的第1行的元素
[1] 1 3 5
> x[2,c(1,3)]    #取矩陣x的行第2的第1,3列的元素
[1] 2 6
> class(x[1,2])   # x[1,2] 類型竟不是矩陣格式
[1] "integer"
> x[1,2, drop = FALSE]  #得到 x[1,2] 類型是矩陣格式
> class(x[1,2, drop = FALSE] )
[1] "matrix"

2.13 取數(shù)據(jù)框子集

x = data.frame(v = 1:5, c = 6:10, u = 11:15)
x$v[c(2,4)]   #取x 中變量v列的第2,4個元素
x[,2]  
x[,"v"]    #二者都表示取同1列
x[(x$v < 4  &  x$c >= 8), ]     #取v變量小于4 且 c變量大于8的數(shù)據(jù)行
x[x$v > 2, ]    #取v變量大于4的數(shù)據(jù)行
x[which(x$v > 2), ]      #取v變量大于4的數(shù)據(jù)行  二者結果一致 但有所不同
> x$v > 2         #返回邏輯值
[1] FALSE FALSE  TRUE  TRUE  TRUE
> which(x$v > 2)     #返回下標(位置)
[1] 3 4 5 

> subset(x, x$v > 2)   #取v變量大于4的數(shù)據(jù)行  

2.14 取列表子集

> x = list(id = 1:4, height = 170, gender = "male")
> x
$id
[1] 1 2 3 4

$height
[1] 170

$gender
[1] "male"
x[1]       #取到名稱 和 內容
x["id"]      #取到名稱 和 內容
$id
[1] 1 2 3 4

x[[1]]      #只取內容
x[["id"]]    #只取內容
> [1] 1 2 3 4

列表中含有列表的時候

> x = list( a = list(1,2,3,4), b = c("a","d","e"))
> x
$a
$a[[1]]
[1] 1

$a[[2]]
[1] 2

$a[[3]]
[1] 3

$a[[4]]
[1] 4


$b
[1] "a" "d" "e"

> x[[1]][[2]]     #取元素里的內容
> [1] 2
> x[[1]][2]      #取元素
[[1]]
[1] 2
> x[[c(1,3)]]     #取元素
[1] 3
> x[[c(2,2)]]      #取元素
[1] "d"

2.15 處理缺失值

> x = c(1,NA,3,NA,8)
> is.na(x)         #x中是否有缺失值
[1] FALSE  TRUE FALSE  TRUE FALSE
> x[!is.na(x)]      #取不是缺失值的元素
[1] 1 3 8

> y = c(1,NA,3,NA,8)
> z = c("a", "b", "NA", "NA", "d") 
> w = complete.cases(y,z)    #取二者對應都不是缺失值的數(shù)據(jù)
[1]  TRUE FALSE  TRUE FALSE  TRUE
> x[w]
[1] 1 3 8
> z[w]
[1] "a"  "NA" "d"    #似乎有些問題  但我不知道哪兒錯了

> library(datasets)
> nrow(airquality)         #153行
> head(airquality,10)      #airquality前10行
   Ozone Solar.R Wind Temp Month Day
1     41     190  7.4   67     5   1
2     36     118  8.0   72     5   2
3     12     149 12.6   74     5   3
4     18     313 11.5   62     5   4
5     NA      NA 14.3   56     5   5
6     28      NA 14.9   66     5   6
7     23     299  8.6   65     5   7
8     19      99 13.8   59     5   8
9      8      19 20.1   61     5   9
10    NA     194  8.6   69     5  10
> g = complete.cases(airquality)    #檢測每一行是否有缺失值
> g
  [1]  TRUE  TRUE  TRUE  TRUE FALSE FALSE  TRUE  TRUE  TRUE FALSE FALSE  TRUE  TRUE
 [14]  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE FALSE FALSE
 [27] FALSE  TRUE  TRUE  TRUE  TRUE FALSE FALSE FALSE FALSE FALSE FALSE  TRUE FALSE
 [40]  TRUE  TRUE FALSE FALSE  TRUE FALSE FALSE  TRUE  TRUE  TRUE  TRUE  TRUE FALSE
 [53] FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE  TRUE  TRUE  TRUE FALSE
 [66]  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE FALSE  TRUE  TRUE FALSE  TRUE  TRUE  TRUE
 [79]  TRUE  TRUE  TRUE  TRUE FALSE FALSE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE
 [92]  TRUE  TRUE  TRUE  TRUE FALSE FALSE FALSE  TRUE  TRUE  TRUE FALSE FALSE  TRUE
[105]  TRUE  TRUE FALSE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE FALSE  TRUE  TRUE
[118]  TRUE FALSE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE
[131]  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE
[144]  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE FALSE  TRUE  TRUE  TRUE
> airquality[g,][1:10,]    #選擇沒有缺失值(g)的觀測的前10行
   Ozone Solar.R Wind Temp Month Day
1     41     190  7.4   67     5   1
2     36     118  8.0   72     5   2
3     12     149 12.6   74     5   3
4     18     313 11.5   62     5   4
7     23     299  8.6   65     5   7
8     19      99 13.8   59     5   8
9      8      19 20.1   61     5   9
12    16     256  9.7   69     5  12
13    11     290  9.2   66     5  13
14    14     274 10.9   68     5  14

后續(xù)請參考:
R語言基礎之第部分 : 5種數(shù)據(jù)對象類型
R語言基礎之第部分:重要函數(shù)apply族函數(shù)的使用
R語言基礎之第部分 : 排序
R語言基礎之第部分 : 總結數(shù)據(jù)信息

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末阴挣,一起剝皮案震驚了整個濱河市装盯,隨后出現(xiàn)的幾起案子骚秦,更是在濱河造成了極大的恐慌碍舍,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,290評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件驱负,死亡現(xiàn)場離奇詭異嗦玖,居然都是意外死亡,警方通過查閱死者的電腦和手機跃脊,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,107評論 2 385
  • 文/潘曉璐 我一進店門宇挫,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人酪术,你說我怎么就攤上這事器瘪。” “怎么了绘雁?”我有些...
    開封第一講書人閱讀 156,872評論 0 347
  • 文/不壞的土叔 我叫張陵橡疼,是天一觀的道長。 經(jīng)常有香客問我庐舟,道長欣除,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,415評論 1 283
  • 正文 為了忘掉前任挪略,我火速辦了婚禮耻涛,結果婚禮上,老公的妹妹穿的比我還像新娘瘟檩。我一直安慰自己抹缕,他們只是感情好,可當我...
    茶點故事閱讀 65,453評論 6 385
  • 文/花漫 我一把揭開白布墨辛。 她就那樣靜靜地躺著卓研,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上奏赘,一...
    開封第一講書人閱讀 49,784評論 1 290
  • 那天寥闪,我揣著相機與錄音,去河邊找鬼磨淌。 笑死疲憋,一個胖子當著我的面吹牛,可吹牛的內容都是我干的梁只。 我是一名探鬼主播缚柳,決...
    沈念sama閱讀 38,927評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼搪锣!你這毒婦竟也來了秋忙?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,691評論 0 266
  • 序言:老撾萬榮一對情侶失蹤构舟,失蹤者是張志新(化名)和其女友劉穎灰追,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體狗超,經(jīng)...
    沈念sama閱讀 44,137評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡弹澎,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,472評論 2 326
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了努咐。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片裁奇。...
    茶點故事閱讀 38,622評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖麦撵,靈堂內的尸體忽然破棺而出刽肠,到底是詐尸還是另有隱情,我是刑警寧澤免胃,帶...
    沈念sama閱讀 34,289評論 4 329
  • 正文 年R本政府宣布音五,位于F島的核電站,受9級特大地震影響羔沙,放射性物質發(fā)生泄漏躺涝。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,887評論 3 312
  • 文/蒙蒙 一扼雏、第九天 我趴在偏房一處隱蔽的房頂上張望坚嗜。 院中可真熱鬧,春花似錦诗充、人聲如沸苍蔬。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽碟绑。三九已至俺猿,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間格仲,已是汗流浹背押袍。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留凯肋,地道東北人谊惭。 一個月前我還...
    沈念sama閱讀 46,316評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像侮东,于是被迫代替她去往敵國和親圈盔。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,490評論 2 348

推薦閱讀更多精彩內容

  • 學習目標 演示如何從現(xiàn)有的數(shù)據(jù)結構中取子集,合并及創(chuàng)建新數(shù)據(jù)集木缝。 導出數(shù)據(jù)表和圖以供在R環(huán)境以外使用便锨。 1.數(shù)據(jù)框...
    小潔忘了怎么分身閱讀 4,437評論 1 10
  • 取子集操作 R 語言的取子集操作既強大又迅速。 掌握了取子集操作可以讓你實現(xiàn)其它語言無 法完成的復雜操作我碟。 學習取...
    Liam_ml閱讀 1,916評論 0 2
  • 《R語言入門》的讀書筆記 本書的重點內容及感悟: 第一章 導言 1放案、R是一個有著統(tǒng)計分析功能及強大作圖功能的軟件系...
    格式化_001閱讀 12,583評論 0 9
  • 由于最近鄭州市區(qū)業(yè)績不理想,想和朋友一起換一個方向去展業(yè)矫俺,就想到了登封吱殉。 白天公司開完會就接上華夏朋友先去了新密收...
    翻滾吧海闊天空閱讀 240評論 1 10
  • 心情無比地壓抑與沉重,幾近昏沉的大腦厘托,感覺再也裝不下任何的人與事了友雳,恍若,我越想要去抓住那些靜靜呆在紙上的文字铅匹,它...
    黍苗隰桑閱讀 743評論 0 0