<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          Pandas 中 Apply 函數(shù)加速百倍的技巧

          共 4646字,需瀏覽 10分鐘

           ·

          2022-08-01 21:50

          [ 引言 ] 雖然目前dask,cudf等包的出現(xiàn),使得我們的數(shù)據(jù)處理大大得到了加速,但是并不是每個人都有比較好的gpu,非常多的朋友仍然還在使用pandas工具包,但有時候真的很無奈,pandas的許多問題我們都需要使用apply函數(shù)來進(jìn)行處理,而apply函數(shù)是非常慢的,本文我們就介紹如何加速apply函數(shù)600倍的技巧。

          實驗對比

          01 Apply(Baseline)

          我們以Apply為例,原始的Apply函數(shù)處理下面這個問題,需要18.4s的時間。

          import pandas as pd
          import numpy as np
          df = pd.DataFrame(np.random.randint(011, size=(10000005)), columns=('a','b','c','d','e'))
          def func(a,b,c,d,e):
              if e == 10:
                  return c*d
              elif (e < 10and (e>=5):
                  return c+d
              elif e < 5:
                  return a+b
          %%time
          df['new'] = df.apply(lambda x: func(x['a'], x['b'], x['c'], x['d'], x['e']), axis=1)
          CPU times: user 17.9 s, sys: 301 ms, total: 18.2 s
          Wall time: 18.4 s

          02 Swift加速

          因為處理是并行的,所以我們可以使用Swift進(jìn)行加速,在使用Swift之后,相同的操作在我的機(jī)器上可以提升到7.67s。

          %%time
          # !pip install swifter
          import swifter
          df['new'] = df.swifter.apply(lambda x : func(x['a'],x['b'],x['c'],x['d'],x['e']),axis=1)
          HBox(children=(HTML(value='Dask Apply'), FloatProgress(value=0.0, max=16.0), HTML(value='')))

          CPU times: user 329 ms, sys: 240 ms, total: 569 ms
          Wall time: 7.67 s

          03 向量化

          使用Pandas和Numpy的最快方法是將函數(shù)向量化。如果我們的操作是可以直接向量化的話,那么我們就盡可能的避免使用:

          • for循環(huán);
          • 列表處理;
          • apply等操作

          在將上面的問題轉(zhuǎn)化為下面的處理之后,我們的時間縮短為:421 ms。

          %%time
          df['new'] = df['c'] * df['d'#default case e = =10
          mask = df['e'] < 10
          df.loc[mask,'new'] = df['c'] + df['d']
          mask = df['e'] < 5
          df.loc[mask,'new'] = df['a'] + df['b']
          CPU times: user 134 ms, sys: 149 ms, total: 283 ms
          Wall time421 ms

          04 類別轉(zhuǎn)化+向量化

          我們先將上面的類別轉(zhuǎn)化為int16型,再進(jìn)行相同的向量化操作,發(fā)現(xiàn)時間縮短為:116 ms。

          for col in ('a','b','c','d'):
              df[col] = df[col].astype(np.int16) 
          %%time
          df['new'] = df['c'] * df['d'#default case e = =10
          mask = df['e'] < 10
          df.loc[mask,'new'] = df['c'] + df['d']
          mask = df['e'] < 5
          df.loc[mask,'new'] = df['a'] + df['b']
          CPU times: user 71.3 ms, sys: 42.5 ms, total: 114 ms
          Wall time116 ms

          05 轉(zhuǎn)化為values處理

          在能轉(zhuǎn)化為.values的地方盡可能轉(zhuǎn)化為.values,再進(jìn)行操作。

          • 此處先轉(zhuǎn)化為.values等價于轉(zhuǎn)化為numpy,這樣我們的向量化操作會更加快捷。

          于是,上面的操作時間又被縮短為:74.9ms。

          %%time
          df['new'] = df['c'].values * df['d'].values #default case e = =10
          mask = df['e'].values < 10
          df.loc[mask,'new'] = df['c'] + df['d']
          mask = df['e'].values < 5
          df.loc[mask,'new'] = df['a'] + df['b']
          CPU times: user 64.5 ms, sys: 12.5 ms, total: 77 ms
          Wall time74.9 ms

          實驗匯總

          通過上面的一些小的技巧,我們將簡單的Apply函數(shù)加速了幾百倍,具體的:

          • Apply: 18.4 s
          • Apply + Swifter: 7.67 s
          • Pandas vectorizatoin: 421 ms
          • Pandas vectorization + data types: 116 ms
          • Pandas vectorization + values + data types: 74.9ms

          本文大部分內(nèi)容參考引文

          參考文獻(xiàn):Do You Use Apply in Pandas? There is a 600x Faster Way

          作者:程序員小八

          https://blog.csdn.net/z099164/article/details/122379538




          推薦閱讀:

          入門: 最全的零基礎(chǔ)學(xué)Python的問題  | 零基礎(chǔ)學(xué)了8個月的Python  | 實戰(zhàn)項目 |學(xué)Python就是這條捷徑


          干貨:爬取豆瓣短評,電影《后來的我們》 | 38年NBA最佳球員分析 |   從萬眾期待到口碑撲街!唐探3令人失望  | 笑看新倚天屠龍記 | 燈謎答題王 |用Python做個海量小姐姐素描圖 |碟中諜這么火,我用機(jī)器學(xué)習(xí)做個迷你推薦系統(tǒng)電影


          趣味:彈球游戲  | 九宮格  | 漂亮的花 | 兩百行Python《天天酷跑》游戲!


          AI: 會做詩的機(jī)器人 | 給圖片上色 | 預(yù)測收入 | 碟中諜這么火,我用機(jī)器學(xué)習(xí)做個迷你推薦系統(tǒng)電影


          小工具: Pdf轉(zhuǎn)Word,輕松搞定表格和水?。?/a> | 一鍵把html網(wǎng)頁保存為pdf!|  再見PDF提取收費(fèi)! | 用90行代碼打造最強(qiáng)PDF轉(zhuǎn)換器,word、PPT、excel、markdown、html一鍵轉(zhuǎn)換 | 制作一款釘釘?shù)蛢r機(jī)票提示器! |60行代碼做了一個語音壁紙切換器天天看小姐姐!



          年度爆款文案

          點(diǎn)閱讀原文,看B站我的視頻!

          瀏覽 38
          點(diǎn)贊
          評論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報
          評論
          圖片
          表情
          推薦
          點(diǎn)贊
          評論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  性色网站 | 韩国毛片在线播放 | 艹b网站在线观看 | 黄色成人片 | 亚洲中文字幕一区二区 |