色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
电子发烧友
开通电子发烧友VIP会员 尊享10大特权
海量资料免费下载
精品直播免费看
优质内容免费畅学
课程9折专享价
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Pandas中使用Merge、Join、Concat合并數(shù)據(jù)的效率對(duì)比

數(shù)據(jù)分析與開發(fā) ? 來(lái)源:Deephub Imba ? 作者:Deephub Imba ? 2022-10-25 14:24 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

在 Pandas 中有很多種方法可以進(jìn)行DF的合并。

本文將研究這些不同的方法,以及如何將它們執(zhí)行速度的對(duì)比。

合并

Pandas 使用 .merge() 方法來(lái)執(zhí)行合并。

importpandasaspd

#adictionarytoconverttoadataframe
data1={'identification':['a','b','c','d'],
'Customer_Name':['King','West','Adams','Mercy'],'Category':['furniture','OfficeSupplies','Technology','R_materials'],}

#ourseconddictionarytoconverttoadataframe
data2={'identification':['a','b','c','d'],
'Class':['First_Class','Second_Class','Same_day','StandardClass'],
'Age':[60,30,40,50]}

#ConvertthedictionaryintoDataFrame
df1=pd.DataFrame(data1)
df2=pd.DataFrame(data2)
運(yùn)行我們的代碼后,有兩個(gè) DataFrame,如下所示。
identificationCustomer_NameCategory
0aKingfurniture
1bWestOfficeSupplies
2cAdamsTechnology
3dMercyR_materials

identificationClassAge
0aFirst_Class60
1bSecond_Class30
2cSame_day40
3dStandardClass50

使用 merge() 函數(shù)進(jìn)一步合并。

2adbf736-541f-11ed-a3b6-dac502259ad0.png

#using.merge()function
new_data=pd.merge(df1,df2,on='identification')
這產(chǎn)生了下面的新數(shù)據(jù);
identificationCustomer_NameCategoryClassAge
0aKingfurnitureFirst_Class60
1bWestOfficeSuppliesSecond_Class30
2cAdamsTechnologySame_day40
3dMercyR_materialsStandardClass50

.join() 方法也可以將不同索引的 DataFrame 組合成一個(gè)新的 DataFrame。我們可以使用參數(shù)‘on’參數(shù)指定根據(jù)哪列進(jìn)行合并。

2b01b5b6-541f-11ed-a3b6-dac502259ad0.png ? 讓我們看看下面的例子,我們?nèi)绾螌嗡饕?DataFrame 與多索引 DataFrame 連接起來(lái);

importpandasaspd

#adictionarytoconverttoadataframe
data1={
'Customer_Name':['King','West','Adams'],
'Category':['furniture','OfficeSupplies','Technology'],}7
#ourseconddictionarytoconverttoadataframe
data2={
'Class':['First_Class','Second_Class','Same_day','StandardClass'],
'Age':[60,30,40,50]}

#ConvertthedictionaryintoDataFrame
Ndata=pd.DataFrame(data1,index=pd.Index(['a','b','c'],name='identification'))

index=pd.MultiIndex.from_tuples([('a','x0'),('b','x1'),
('c','x2'),('c','x3')],
names=['identification','x'])19
#ConvertthedictionaryintoDataFrame
Ndata2=pd.DataFrame(data2,index=index)

print(Ndata,"

",Ndata2)


#joiningsinglyindexedwith
#multiindexed
result=Ndata.join(Ndata2,how='inner')

我們的結(jié)果如下所示;

Customer_NameCategoryClassAge
identificationx3ax0KingfurnitureFirst_Class60
bx1WestOfficeSuppliesSecond_Class30
cx2AdamsTechnologySame_day40
x3AdamsTechnologyStandardClass50

連接DF

Pandas 中concat() 方法在可以在垂直方向(axis=0)和水平方向(axis=1)上連接 DataFrame。我們還可以一次連接兩個(gè)以上的 DataFrame 或 Series。

讓我們看一個(gè)如何在 Pandas 中執(zhí)行連接的示例;

importpandasaspd

#adictionarytoconverttoadataframe
data1={'identification':['a','b','c','d'],
'Customer_Name':['King','West','Adams','Mercy'],
'Category':['furniture','OfficeSupplies','Technology','R_materials'],}

#ourseconddictionarytoconverttoadataframe
data2={'identification':['a','b','c','d'],
'Class':['First_Class','Second_Class','Same_day','StandardClass'],
'Age':[60,30,40,50]}

#ConvertthedictionaryintoDataFrame
df1=pd.DataFrame(data1)
df2=pd.DataFrame(data2)
#performconcatenationherebasedonhorizontalaxis
new_data=pd.concat([df1,df2],axis=1)
print(new_data)
這樣就獲得了新的 DataFrame :
identificationCustomer_NameCategoryidentification
0aKingfurniturea31bWestOfficeSuppliesb42cAdamsTechnologyc53dMercyR_materialsd

ClassAge
0First_Class60
1Second_Class30
2Same_day40
3StandardClass50

Merge和Join的效率對(duì)比

Pandas 中的Merge Joins操作都可以針對(duì)指定的列進(jìn)行合并操作(SQL中的join)那么他們的執(zhí)行效率是否相同呢?下面我們來(lái)進(jìn)行一下測(cè)。 兩個(gè) DataFrame 都有相同數(shù)量的行和兩列,實(shí)驗(yàn)中考慮了從 100 萬(wàn)行到 1000 萬(wàn)行的不同大小的 DataFrame,并在每次實(shí)驗(yàn)中將行數(shù)增加了 100 萬(wàn)。我對(duì)固定數(shù)量的行重復(fù)了十次實(shí)驗(yàn),以消除任何隨機(jī)性。下面是這十次試驗(yàn)中合并操作的平均運(yùn)行時(shí)間。

2b2f5282-541f-11ed-a3b6-dac502259ad0.png

上圖描繪了操作所花費(fèi)的時(shí)間(以毫秒為單位)。

正如我們從圖中看到的,運(yùn)行時(shí)間存在顯著差異——最多相差 5 倍。隨著 DataFrame 大小的增加,運(yùn)行時(shí)間之間的差異也會(huì)增加。兩個(gè) JOIN 操作幾乎都隨著 DataFrame 的大小線性增加。但是,Join的運(yùn)行時(shí)間增加的速度遠(yuǎn)低于Merge。

如果需要處理大量數(shù)據(jù),還是請(qǐng)使用join()進(jìn)行操作。

審核編輯:湯梓紅
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 函數(shù)
    +關(guān)注

    關(guān)注

    3

    文章

    4379

    瀏覽量

    64801
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4900

    瀏覽量

    70663
  • merge
    +關(guān)注

    關(guān)注

    0

    文章

    5

    瀏覽量

    2566
  • concat
    +關(guān)注

    關(guān)注

    0

    文章

    3

    瀏覽量

    1986

原文標(biāo)題:Pandas 中使用 Merge、Join 、Concat 合并數(shù)據(jù)的效率對(duì)比

文章出處:【微信號(hào):DBDevs,微信公眾號(hào):數(shù)據(jù)分析與開發(fā)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 0人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    pandas數(shù)據(jù)分析的方法

    pandas數(shù)據(jù)分析中常用方法
    發(fā)表于 06-03 06:16

    Fork/Join的框架機(jī)制詳解

    策略在分布式數(shù)據(jù)庫(kù)中非常常見,數(shù)據(jù)分布在不同的數(shù)據(jù)庫(kù)的副本中,在執(zhí)行查詢時(shí),每個(gè)服務(wù)都要跑查詢?nèi)蝿?wù),最后在一個(gè)服務(wù)上做數(shù)據(jù)合并,或者提供一個(gè)
    發(fā)表于 01-05 17:51

    pandas是什么

    提示:文章寫完后,目錄可以自動(dòng)生成,如何生成可參考右邊的幫助文檔文章目錄前言一、pandas是什么?二、使用步驟1.引入庫(kù)2.讀入數(shù)據(jù)總結(jié)前言提示:這里可以添加本文要記錄的大概內(nèi)容:例如:隨著
    發(fā)表于 08-09 07:39

    pandas使用步驟

    提示:文章寫完后,目錄可以自動(dòng)生成,如何生成可參考右邊的幫助文檔文章目錄前言一、pandas是什么?二、使用步驟1.引入庫(kù)2.讀入數(shù)據(jù)總結(jié)學(xué)習(xí)內(nèi)容:學(xué)習(xí)時(shí)間:學(xué)習(xí)產(chǎn)出:前言一、pandas是什么?二
    發(fā)表于 08-10 07:50

    pandas是什么?

    文章目錄前言一、pandas是什么?二、使用步驟1.引入庫(kù)2.讀入數(shù)據(jù)總結(jié)前言一、pandas是什么?二、使用步驟1.引入庫(kù)代碼如下(示例):import numpy as npimport
    發(fā)表于 01-11 07:53

    pandas是什么?

    提示:文章寫完后,目錄可以自動(dòng)生成,如何生成可參考右邊的幫助文檔文章目錄前言一、pandas是什么?二、使用步驟1.引入庫(kù)2.讀入數(shù)據(jù)總結(jié)前言提示:這里可以添加本文要記錄的大概內(nèi)容:例如:隨著
    發(fā)表于 01-12 07:53

    對(duì)于mergejoinconcat三者的區(qū)別分析

    合并的方式看mergejoin是一樣的,有l(wèi)eft/right/inner/outer,而concat只有inner/outer兩種,因?yàn)?b class='flag-5'>mer
    的頭像 發(fā)表于 01-06 11:55 ?2.1w次閱讀
    對(duì)于<b class='flag-5'>merge</b>、<b class='flag-5'>join</b>和<b class='flag-5'>concat</b>三者的區(qū)別分析

    Git命令解析-merge、rebase

    把feature的分支代碼合并回到master,通常執(zhí)行的操作是先檢出master分支,然后執(zhí)行g(shù)it merge feature。一般來(lái)說(shuō),在單人開發(fā)的情況下,merge通常會(huì)產(chǎn)生快進(jìn)(fast-forward
    的頭像 發(fā)表于 07-29 18:21 ?1293次閱讀
    Git命令解析-<b class='flag-5'>merge</b>、rebase

    5個(gè)必須知道的Pandas數(shù)據(jù)合并技巧

    concatpandas中專門用于數(shù)據(jù)連接合并的函數(shù),功能非常強(qiáng)大,支持縱向合并和橫向合并,默
    的頭像 發(fā)表于 04-13 10:35 ?2576次閱讀

    應(yīng)用層關(guān)聯(lián)的優(yōu)勢(shì) MySQL不推薦使用join的原因

    對(duì)于mysql,不推薦使用子查詢和join是因?yàn)楸旧?b class='flag-5'>join的效率就是硬傷,一旦數(shù)據(jù)量很大效率就很難保證,強(qiáng)烈推薦分別根據(jù)索引單表取
    發(fā)表于 02-23 14:07 ?604次閱讀

    如何優(yōu)化MySQL中的join語(yǔ)句

    在mysql中,join 主要有Nested Loop、Hash JoinMerge Join 這三種方式,我們今天來(lái)看一下最普遍 Nested Loop 循環(huán)連接方式,主要包括三種
    的頭像 發(fā)表于 04-24 17:03 ?1049次閱讀
    如何優(yōu)化MySQL中的<b class='flag-5'>join</b>語(yǔ)句

    Python Pandas如何來(lái)管理結(jié)構(gòu)化數(shù)據(jù)

    和DataFrame)。 ? 在人工智能領(lǐng)域,Pandas經(jīng)常用于機(jī)器學(xué)習(xí)和深度學(xué)習(xí)過(guò)程的預(yù)處理步驟。Pandas通過(guò)提供數(shù)據(jù)清理、重塑、合并和聚合,可以將原始
    的頭像 發(fā)表于 05-25 11:22 ?924次閱讀
    Python <b class='flag-5'>Pandas</b>如何來(lái)管理結(jié)構(gòu)化<b class='flag-5'>數(shù)據(jù)</b>

    git rebase和git merge的區(qū)別

    ? 解決沖突 git rebase和git merge的區(qū)別 分支合并 git merge是用來(lái)合并兩個(gè)分支的。 比如:將 b 分支合并到當(dāng)
    的頭像 發(fā)表于 07-05 09:54 ?888次閱讀
    git rebase和git <b class='flag-5'>merge</b>的區(qū)別

    pandas合并數(shù)據(jù)的5個(gè)函數(shù)

    今天借著這個(gè)機(jī)會(huì),就為大家盤點(diǎn)一下pandas合并數(shù)據(jù)的5個(gè)函數(shù)。 join join是基于索引的橫向拼接,如果索引一致,直接橫向拼接。如
    的頭像 發(fā)表于 10-31 11:11 ?1081次閱讀
    <b class='flag-5'>pandas</b>中<b class='flag-5'>合并</b><b class='flag-5'>數(shù)據(jù)</b>的5個(gè)函數(shù)

    Pandas DataFrame的存儲(chǔ)格式性能對(duì)比

    Pandas 支持多種存儲(chǔ)格式,在本文中將對(duì)不同類型存儲(chǔ)格式下的Pandas Dataframe的讀取速度、寫入速度和大小的進(jìn)行測(cè)試對(duì)比。 創(chuàng)建測(cè)試Dataframe 首先創(chuàng)建一個(gè)包含不同類型
    的頭像 發(fā)表于 11-03 09:58 ?809次閱讀
    <b class='flag-5'>Pandas</b> DataFrame的存儲(chǔ)格式性能<b class='flag-5'>對(duì)比</b>
    主站蜘蛛池模板: 小小水蜜桃3视频在线观看 小向美奈子厨房magnet | 欧美一级做a爰片免费 | 黑人 尺寸 强行害怕 痛哭 | 亚洲黄色在线视频 | 小草观看免费高清视频 | 乱码中字在线观看一二区 | 美国女孩毛片 | 99精品影院 | 同房交换4p好爽 | 精品国产乱码久久久久久软件 | 亚洲无遮挡无码A片在线 | 亚洲欧洲日本天天堂在线观看 | 精品国产乱码久久久久久人妻 | 亚洲AVAV天堂AV在线网爱情 | 亚洲AV综合色一区二区三区 | 果冻传媒视频在线播放 | 在线播放免费人成视频 | 村妇偷人内射高潮迭起 | 国产啪精品视频网免费 | 18黄女脱内衣 | 国产色婷婷亚洲99精品 | 牢记永久免费网址 | 琪琪SEE色原网色原网站18 | 在线观看视频中文字幕 | 天天爽夜夜爽夜夜爽 | 好男人视频免费高清在线观看www | 美女网站免费看 | 在线观看成人3d动漫入口 | 成年女人免费播放影院 | 捆绑白丝粉色JK震动捧喷白浆 | 东北女人奶大毛多水多 | 国内久经典AAAAA片 | 花蝴蝶在线直播观看 | 成人无码在线视频区 | 忘忧草在线影院WWW日本二 | 亚洲日本乱码中文论理在线电影 | 国产一区私人高清影院 | 青柠视频在线观看高清HD | av天堂网2017avtt| 国产精品乱码色情一区二区视频 | 日韩熟女精品一区二区三区 |

    電子發(fā)燒友

    中國(guó)電子工程師最喜歡的網(wǎng)站

    • 2931785位工程師會(huì)員交流學(xué)習(xí)
    • 獲取您個(gè)性化的科技前沿技術(shù)信息
    • 參加活動(dòng)獲取豐厚的禮品