黄色网页视频 I 影音先锋日日狠狠久久 I 秋霞午夜毛片 I 秋霞一二三区 I 国产成人片无码视频 I 国产 精品 自在自线 I av免费观看网站 I 日本精品久久久久中文字幕5 I 91看视频 I 看全色黄大色黄女片18 I 精品不卡一区 I 亚洲最新精品 I 欧美 激情 在线 I 人妻少妇精品久久 I 国产99视频精品免费专区 I 欧美影院 I 欧美精品在欧美一区二区少妇 I av大片网站 I 国产精品黄色片 I 888久久 I 狠狠干最新 I 看看黄色一级片 I 黄色精品久久 I 三级av在线 I 69色综合 I 国产日韩欧美91 I 亚洲精品偷拍 I 激情小说亚洲图片 I 久久国产视频精品 I 国产综合精品一区二区三区 I 色婷婷国产 I 最新成人av在线 I 国产私拍精品 I 日韩成人影音 I 日日夜夜天天综合

幾個方法幫你加快Python運行速度

系統(tǒng) 2130 0

Python運行的慢是歷來被詬病的,一方面和語言有關(guān),另一方面可能就是你代碼的問題。語言方面的問題我們解決不了,所以只能在編程技巧上來提高程序的運行效率。下面就給大家分享幾個提高運行效率的編程方法。

首先,我們需要來衡量代碼的時間和空間的復(fù)雜性,不然僅僅用我們的肉眼很難感受代碼時間長短的變化。python中的profiler可以幫助我們測量程序的時間和空間復(fù)雜度。 使用時通過-o參數(shù)傳入可選輸出文件以保留性能日志。具體使用方法如下:

python -m cProfile [-o output_file] my_python_file.py

01 使用哈希表的數(shù)據(jù)結(jié)構(gòu)

如果在程序中遇到大量搜索操作時,并且數(shù)據(jù)中沒有重復(fù)項,則可以使用查找而不是循環(huán)。舉例如下:

幾個方法幫你加快Python運行速度_第1張圖片

可以改寫為

幾個方法幫你加快Python運行速度_第2張圖片

02 矢量化取代循環(huán)

盡量使用基于C構(gòu)建的Python庫,例如Numpy,Scipy和Pandas,并且利用矢量化同時處理來取代程序中編寫多次處理數(shù)組單個元素的循環(huán),循環(huán)可能是程序優(yōu)化最容易被拿來開刀的地方了。舉例如下:在對數(shù)組中每個元素求平方時直接用數(shù)組相乘,而不是兩個for循環(huán)。

03 精簡代碼行數(shù)

在編程時,盡量使用一些python的內(nèi)置函數(shù)來精簡代碼行數(shù),是代碼顯得簡潔凝練,大大提高代碼運行效率。舉例如下:

幾個方法幫你加快Python運行速度_第3張圖片

可以改寫為

04 使用多進程

一般計算機都是多進程的,那么在執(zhí)行操作時可以使用Python中的multiproccessing。多進程可在代碼中實現(xiàn)并行化。 當(dāng)您要實例化新進程,訪問共享內(nèi)存時,多進程成本很高,因此如果有大量數(shù)據(jù)處理時可以考慮使用多進程。 對于少量數(shù)據(jù),則不提倡使用多進程。舉例如下:

幾個方法幫你加快Python運行速度_第4張圖片

可以改寫為

幾個方法幫你加快Python運行速度_第5張圖片

05 使用Cpython

Cython是一個靜態(tài)編譯器,可以為您優(yōu)化代碼。加載cypthonmagic擴展并使用cython標(biāo)記使用cython編譯代碼。

Cpython的安裝:

pip install Cython

Cpython的使用:

06 盡量使用csv替代xlsx

在進行數(shù)據(jù)處理時, 我需要更長的時間才能將數(shù)據(jù)加載到excel文件或從excel文件保存數(shù)據(jù)。 相反,我選擇了創(chuàng)建多個csv文件的路徑,并創(chuàng)建了一個文件夾來對文件進行分組。舉例如下:

幾個方法幫你加快Python運行速度_第6張圖片

可以改寫為

幾個方法幫你加快Python運行速度_第7張圖片

07 使用Numba

它是一個JIT(即時)編譯器。 通過裝飾器,Numba將帶注釋的Python和NumPy代碼編譯為LLVM 。將您的功能分為兩部分:

1.執(zhí)行計算的函數(shù) - 使用@autojit進行裝飾

2.執(zhí)行IO的功能

幾個方法幫你加快Python運行速度_第8張圖片

08 使用Dask來并行化Pandas DataFrame

Dask很棒! 它幫助我處理數(shù)據(jù)框中的數(shù)值函數(shù)和并行的numpy。 我甚至試圖在集群上擴展它,它就是這么簡單!

幾個方法幫你加快Python運行速度_第9張圖片

09 使用Pandarallel庫

Pandarallel可以將pandas操作與多個進程并行化同樣,僅在您擁有大型數(shù)據(jù)集時使用。

幾個方法幫你加快Python運行速度_第10張圖片

總結(jié)

對于提高Python的性能,第一是先編寫簡潔,高效的代碼。 我們必須確保代碼不會在循環(huán)中反復(fù)執(zhí)行相同的計算。第二不要為集合中的每個記錄打開/關(guān)閉IO連接。第三要確保在不需要時不創(chuàng)建新的對象實例。通過大量的編程練習(xí),掌握一些高級的編程方法對你十分重要。


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論