精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Pandas中使用Merge、Join、Concat合并數據的效率對比

數據分析與開發 ? 來源:Deephub Imba ? 作者:Deephub Imba ? 2022-10-25 14:24 ? 次閱讀

在 Pandas 中有很多種方法可以進行DF的合并。

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

合并

Pandas 使用 .merge() 方法來執行合并。

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)
運行我們的代碼后,有兩個 DataFrame,如下所示。
identificationCustomer_NameCategory
0aKingfurniture
1bWestOfficeSupplies
2cAdamsTechnology
3dMercyR_materials

identificationClassAge
0aFirst_Class60
1bSecond_Class30
2cSame_day40
3dStandardClass50

使用 merge() 函數進一步合并。

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

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

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

2b01b5b6-541f-11ed-a3b6-dac502259ad0.png ? 讓我們看看下面的例子,我們如何將單索引 DataFrame 與多索引 DataFrame 連接起來;

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')

我們的結果如下所示;

Customer_NameCategoryClassAge
identificationx3ax0KingfurnitureFirst_Class60
bx1WestOfficeSuppliesSecond_Class30
cx2AdamsTechnologySame_day40
x3AdamsTechnologyStandardClass50

連接DF

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

讓我們看一個如何在 Pandas 中執行連接的示例;

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的效率對比

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

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

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

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

如果需要處理大量數據,還是請使用join()進行操作。

審核編輯:湯梓紅
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 函數
    +關注

    關注

    3

    文章

    4307

    瀏覽量

    62432
  • 代碼
    +關注

    關注

    30

    文章

    4750

    瀏覽量

    68357
  • merge
    +關注

    關注

    0

    文章

    5

    瀏覽量

    2470
  • concat
    +關注

    關注

    0

    文章

    3

    瀏覽量

    1911

原文標題:Pandas 中使用 Merge、Join 、Concat 合并數據的效率對比

文章出處:【微信號:DBDevs,微信公眾號:數據分析與開發】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    pandas數據分析的方法

    pandas數據分析中常用方法
    發表于 06-03 06:16

    Fork/Join的框架機制詳解

    策略在分布式數據庫中非常常見,數據分布在不同的數據庫的副本中,在執行查詢時,每個服務都要跑查詢任務,最后在一個服務上做數據合并,或者提供一個
    發表于 01-05 17:51

    pandas是什么

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

    pandas使用步驟

    提示:文章寫完后,目錄可以自動生成,如何生成可參考右邊的幫助文檔文章目錄前言一、pandas是什么?二、使用步驟1.引入庫2.讀入數據總結學習內容:學習時間:學習產出:前言一、pandas是什么?二
    發表于 08-10 07:50

    pandas是什么?

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

    pandas是什么?

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

    對于mergejoinconcat三者的區別分析

    合并的方式看mergejoin是一樣的,有left/right/inner/outer,而concat只有inner/outer兩種,因為mer
    的頭像 發表于 01-06 11:55 ?2w次閱讀
    對于<b class='flag-5'>merge</b>、<b class='flag-5'>join</b>和<b class='flag-5'>concat</b>三者的區別分析

    Git命令解析-merge、rebase

    把feature的分支代碼合并回到master,通常執行的操作是先檢出master分支,然后執行git merge feature。一般來說,在單人開發的情況下,merge通常會產生快進(fast-forward
    的頭像 發表于 07-29 18:21 ?1057次閱讀
    Git命令解析-<b class='flag-5'>merge</b>、rebase

    5個必須知道的Pandas數據合并技巧

    concatpandas中專門用于數據連接合并的函數,功能非常強大,支持縱向合并和橫向合并,默
    的頭像 發表于 04-13 10:35 ?2292次閱讀

    應用層關聯的優勢 MySQL不推薦使用join的原因

    對于mysql,不推薦使用子查詢和join是因為本身join效率就是硬傷,一旦數據量很大效率就很難保證,強烈推薦分別根據索引單表取
    發表于 02-23 14:07 ?471次閱讀

    如何優化MySQL中的join語句

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

    Python Pandas如何來管理結構化數據

    和DataFrame)。 ? 在人工智能領域,Pandas經常用于機器學習和深度學習過程的預處理步驟。Pandas通過提供數據清理、重塑、合并和聚合,可以將原始
    的頭像 發表于 05-25 11:22 ?661次閱讀
    Python <b class='flag-5'>Pandas</b>如何來管理結構化<b class='flag-5'>數據</b>

    git rebase和git merge的區別

    ? 解決沖突 git rebase和git merge的區別 分支合并 git merge是用來合并兩個分支的。 比如:將 b 分支合并到當
    的頭像 發表于 07-05 09:54 ?621次閱讀
    git rebase和git <b class='flag-5'>merge</b>的區別

    pandas合并數據的5個函數

    今天借著這個機會,就為大家盤點一下pandas合并數據的5個函數。 join join是基于索引的橫向拼接,如果索引一致,直接橫向拼接。如
    的頭像 發表于 10-31 11:11 ?708次閱讀
    <b class='flag-5'>pandas</b>中<b class='flag-5'>合并</b><b class='flag-5'>數據</b>的5個函數

    Pandas DataFrame的存儲格式性能對比

    Pandas 支持多種存儲格式,在本文中將對不同類型存儲格式下的Pandas Dataframe的讀取速度、寫入速度和大小的進行測試對比。 創建測試Dataframe 首先創建一個包含不同類型
    的頭像 發表于 11-03 09:58 ?496次閱讀
    <b class='flag-5'>Pandas</b> DataFrame的存儲格式性能<b class='flag-5'>對比</b>