R語(yǔ)言之左連接的三種實(shí)現(xiàn)操作
數(shù)據(jù)處理中經(jīng)常遇到表連接問(wèn)題,本次介紹R語(yǔ)言中三種左連接方法,這三種是等價(jià)的,不過(guò)會(huì)有時(shí)間快慢問(wèn)題,斟酌使用。
法一:
> data0 <- merge(a,c,all.x=TRUE,by='CELLPHONE')
法二:
> data1 <- sqldf('select a.*,b.* from a left join c on a.CELLPHONE=c.CELLPHONE')
法三:
> data2 <- c[a,on='CELLPHONE']
注意:第三種方法的順序不能寫(xiě)反了。
補(bǔ)充:R語(yǔ)言中的inner_join, full_join, left_join, right_join
在R for Data Science中,作者用了非常直觀的例子解釋了上面的四個(gè)概念。說(shuō)明如下:
我們的數(shù)據(jù)集是這樣的:
x <- tribble( ~key, ~val_x, 1, "x1", 2, "x2", 3, "x3" ) y <- tribble( ~key, ~val_y, 1, "y1", 2, "y2", 4, "y3" )
可以看出,x與y的key都有1,2,但是x的key里面有3,y的key里面有4.
下面我們來(lái)看這四個(gè)概念:
1. inner_join
x %>% inner_join(y, by = "key")
其結(jié)果是
key val_x val_y <dbl> <chr> <chr> 1 x1 y1 2 x2 y2
可以看出,此時(shí)基于key的連接只保留了共同的key值1與2對(duì)應(yīng)的數(shù)據(jù);
2. full_join
x %>% full_join(y, by = "key")
其結(jié)果是
key val_x val_y <dbl> <chr> <chr> 1 x1 y1 2 x2 y2 3 x3 NA 4 NA y3
可以看出,此時(shí)基于key的連接保留了所有key值對(duì)應(yīng)的數(shù)據(jù),當(dāng)相應(yīng)的值不存在的時(shí)候,用NA代替;
3. left_join
x %>% left_join(y, by = "key")
此時(shí)的結(jié)果為
<dbl> <chr> <chr> 1 x1 y1 2 x2 y2 3 x3 NA
可以看出, 此時(shí)基于key的連接只保留了x對(duì)應(yīng)的key值的數(shù)據(jù),當(dāng)相應(yīng)的值不存在的時(shí)候,用NA代替;
4. right_join
x %>% right_join(y, by = "key")
此時(shí)的結(jié)果為
key val_x val_y <dbl> <chr> <chr> 1 x1 y1 2 x2 y2 4 NA y3
可以看出,此時(shí)基于key的連接只保留了y對(duì)應(yīng)的key值的數(shù)據(jù),當(dāng)相應(yīng)的值不存在的時(shí)候,用NA代替。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
- R語(yǔ)言 數(shù)據(jù)表匹配和拼接 merge函數(shù)的使用
- R語(yǔ)言 實(shí)現(xiàn)將1對(duì)多數(shù)據(jù)與1對(duì)1數(shù)據(jù)互換
- R語(yǔ)言 數(shù)據(jù)集行列互換的技巧分享
- R語(yǔ)言 實(shí)現(xiàn)將數(shù)據(jù)框中的字符類(lèi)型數(shù)字轉(zhuǎn)換為數(shù)值
- R語(yǔ)言 Factor類(lèi)型的變量使用說(shuō)明
- R語(yǔ)言 實(shí)現(xiàn)將factor轉(zhuǎn)換成numeric方法
- R語(yǔ)言 實(shí)現(xiàn)data.frame 分組計(jì)數(shù)、求和等
相關(guān)文章
R語(yǔ)言 小數(shù)點(diǎn)位數(shù)的設(shè)置方式
這篇文章主要介紹了R語(yǔ)言 小數(shù)點(diǎn)位數(shù)的設(shè)置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-03-03R語(yǔ)言將變量分組的3種方法實(shí)例(含cut函數(shù)說(shuō)明)
在數(shù)據(jù)處理分析過(guò)程中,變量分組是經(jīng)常遇到的,下面這篇文章主要給大家介紹了關(guān)于R語(yǔ)言將變量分組的3種方法,其中含cut函數(shù)說(shuō)明的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08R語(yǔ)言實(shí)現(xiàn)支持向量機(jī)SVM應(yīng)用案例
本文主要介紹了R語(yǔ)言實(shí)現(xiàn)支持向量機(jī)SVM應(yīng)用案例,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08解決R語(yǔ)言安裝時(shí)出現(xiàn)輯程包不存在的問(wèn)題
這篇文章主要介紹了解決R語(yǔ)言安裝時(shí)出現(xiàn)輯程包不存在的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-04-04R語(yǔ)言常用函數(shù)總結(jié)梳理(基本對(duì)象字符處理?數(shù)學(xué)?統(tǒng)計(jì))
這篇文章主要介紹了R語(yǔ)言常用函數(shù)總結(jié)梳理(基本對(duì)象字符處理?數(shù)學(xué)?統(tǒng)計(jì)),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10淺析R語(yǔ)言中map(映射)與reduce(規(guī)約)
大家在R語(yǔ)言數(shù)據(jù)處理中非常常見(jiàn)map(映射)與reduce(規(guī)約)操作,map表示映射,可以在一個(gè)或多個(gè)列表/向量的每個(gè)位置上應(yīng)用相同函數(shù)進(jìn)行計(jì)算而reduce函數(shù)表示規(guī)約,計(jì)算向量中相鄰的兩個(gè)元素,本文給大家介紹R語(yǔ)言map與reduce的相關(guān)知識(shí),感興趣的朋友一起看看吧2021-05-05R語(yǔ)言-計(jì)算平均值不同函數(shù)的區(qū)別說(shuō)明
這篇文章主要介紹了R語(yǔ)言-計(jì)算平均值不同函數(shù)的區(qū)別說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-04-04R語(yǔ)言符號(hào)知識(shí)點(diǎn)匯總
在本篇文章里小編給大家整理的是一篇關(guān)于R語(yǔ)言符號(hào)知識(shí)點(diǎn)匯總內(nèi)容,有需要的朋友們可以學(xué)習(xí)下。2021-03-03R語(yǔ)言如何畫(huà)豎線(xiàn)、橫線(xiàn)、添加標(biāo)簽以及畫(huà)固定長(zhǎng)度的線(xiàn)段
R語(yǔ)言繪圖的能力非常強(qiáng)大,有時(shí)看似繁復(fù)的圖形不過(guò)寥寥數(shù)行代碼就搞定,下面這篇文章主要給大家介紹了關(guān)于R語(yǔ)言如何畫(huà)豎線(xiàn)、橫線(xiàn)、添加標(biāo)簽以及畫(huà)固定長(zhǎng)度的線(xiàn)段的相關(guān)資料,需要的朋友可以參考下2022-11-11