亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

提升?Python?代碼運行速度的6個技巧

 更新時間:2022年01月26日 09:48:26   作者:Python學習與數(shù)據(jù)挖掘  
本文分享了提升?Python?代碼運行速度的6個技巧,Python?比我們想象的運行的要快。我們之所以有先入為主的認為Python運行慢,可能是我們平常的誤用和缺乏使用技巧知識。接下來讓我們看看如何用一些簡單的Trick來提高我們程序的運行性能,需要的朋友可以參考一下

其實,Python 比我們想象的運行的要快。我們之所以有先入為主的認為Python運行慢,可能是我們平常的誤用和缺乏使用技巧知識。

接下來讓我們看看如何用一些簡單的Trick來提高我們程序的運行性能

1、使用內置函數(shù)

Python中的許多內置函數(shù)都是用C實現(xiàn)的,并且經過了很好的優(yōu)化。因此,如果熟悉這些內置函數(shù),就可以提高Python代碼的性能。一些常用的內置函數(shù)有sum()、len()、map()max()等。

假設我們有一個包含單詞的列表,我們希望每個單詞的首字母均變?yōu)榇髮?。此時使用map()函數(shù)是不錯的選擇。

一般版本:

new_list = []
word_list = ["i", "am", "a", "python", "programmer"]
for word in word_list:
? ? new_list.append(word.capitalize())

改進版本:

word_list = ["i", "am", "a", "python", "programmer"]
new_list = list(map(str.capitalize, word_list))

時間對比:

import time
new_list = []
word_list = ["i", "am", "a", "python", "programmer"]

start = time.time()

for word in word_list:
? ? new_list.append(word.capitalize())
print(time.time() - start, "seconds")

start = time.time()

new_list = list(map(str.capitalize, word_list))
print(time.time() - start, "seconds")

運行結果:

1.0013580322265625e-05 seconds
4.76837158203125e-06 seconds

可以看出第二種方法運行速度快了將近2倍.

2、字符串連接 VS join()

Python中,字符串是不可變的,因此我們不能修改它們。
每次當我們連接多個字符串時,我們將會創(chuàng)建一個新的字符串,此時會導致一些運行性能問題。

一般版本:

new_list = []
word_list = ["I", "am", "a", "Python", "programmer"]
for word in word_list:
? ? new_list += word

改進版本:

word_list = ["I", "am", "a", "Python", "programmer"]
new_list = "".join(word_list)

時間對比:

import time

new_list = []
word_list = ["I", "am", "a", "Python", "programmer"]

start = time.time()
for word in word_list:
? ? new_list += word
print(time.time() - start, "seconds")

start = time.time()
new_list = "".join(word_list)
print(time.time() - start, "seconds")

運行結果:

4.0531158447265625e-06 seconds
9.5367431640625e-07 seconds

使用Join()函數(shù)可以讓代碼運行快4倍.

3、創(chuàng)建列表和字典的方式

一般來說,使用[]和{}來創(chuàng)建列表和字典相比使用list()dict{}運行更加高效.這是因為使用list()dict{}來創(chuàng)建對象時需要調用一個附加函數(shù).

一般版本:

list()
dict()

改進版本:

()
{}

時間對比:

為了便于對比時間,這里我們使用timeit函數(shù)來統(tǒng)計,我們運行1百萬次,來看二者的時間對比,代碼如下:

import timeit

slower_list = timeit.timeit("list()", number=10**6)
slower_dict = timeit.timeit("dict()", number=10**6)

faster_list = timeit.timeit("[]", number=10**6)
faster_dict = timeit.timeit("{}", number=10**6)

print(slower_list, "seconds")
print(slower_dict, "seconds")
print(faster_list, "seconds")
print(faster_dict, "seconds")

運行結果:

0.08825178800000001 seconds
0.083323732 seconds
0.019935448999999994 seconds
0.027835573000000002 seconds

可以看出,我們的運行速度快了將近4倍.

4、使用 f-Strings

我們已經知道將字符串進行串聯(lián)可能會使程序變慢。
另一個比較好的解決方案是使用f-Strings。

一般版本:

me = "Python"
string = "Make " + me + " faster"

改進版本:

me = "Python"
string = f"Make {me} faster"

時間對比:

import time
me = "Python"

start = time.time()
string = "Make " + me + " faster"
print(time.time() - start, "seconds")

start = time.time()
string = f"Make {me} faster"
print(time.time() - start, "seconds")

運行結果:

2.1457672119140625e-06 seconds
9.5367431640625e-07 seconds

可以看出,我們的運行速度快了將近2倍.

5、使用Comprehensions

Python中的List Comprehensions為我們提供了更短的語法,甚至只有一行代碼來實現(xiàn)各種強大的功能。很多用到循環(huán)的場景下,我們盡量使用生成式的語法來實現(xiàn).

一般版本:

new_list = []
existing_list = range(1000000)
for i in existing_list:
? ? if i % 2 == 1:
? ? ? ? new_list.append(i)

較快版本:

existing_list = range(1000000)
new_list = [i for i in existing_list if i % 2 == 1]

時間對比:

import time

new_list = []
existing_list = range(1000000)

start = time.time()
for i in existing_list:
? ? if i % 2 == 1:
? ? ? ? new_list.append(i)
print(time.time() - start, "seconds")

start = time.time()
new_list = [i for i in existing_list if i % 2 == 1]
print(time.time() - start, "seconds")

運行結果:

0.16418218612670898 seconds
0.07834219932556152 seconds

可以看出,我們的運行速度快了將近2倍.

6、附錄- Python中的內置函數(shù)

我們可以通過官網來查看Python的內置函數(shù).

如果我們只關注上述例子中一些短小的代碼片段,這些技巧似乎沒有太大的改善。 實際上,我們的項目很容易變得復雜,此時上述技巧就派上用場啦!

7. 總結

本文重點介紹了在Python中如何使用一些簡單的Trick來提升代碼運行效率,并給出了相應的代碼示例。

相關文章

  • python中的對數(shù)log函數(shù)表示及用法

    python中的對數(shù)log函數(shù)表示及用法

    在本篇文章里小編給大家整理了一篇關于python中的對數(shù)log函數(shù)表示及用法,有需要的朋友們可以學習下。
    2020-12-12
  • Flask SQLAlchemy一對一,一對多的使用方法實踐

    Flask SQLAlchemy一對一,一對多的使用方法實踐

    Flask-SQLAlchemy一對一,一對多的使用方法實踐,需要的朋友可以參考下
    2013-02-02
  • 解析Sentry?Relay?二次開發(fā)調試

    解析Sentry?Relay?二次開發(fā)調試

    這篇文章主要介紹了Sentry?Relay?二次開發(fā)調試簡介,集成測試要求?Redis?和?Kafka?在其默認配置中運行,獲取所有必需服務的最便捷方式是通過?sentry?devservices,這需要最新的?Sentry?開發(fā)環(huán)境,本文給大家介紹的非常詳細,需要的朋友參考下吧
    2022-03-03
  • pycharm運行程序時出現(xiàn)Run‘python tests for XXX.py‘問題及解決

    pycharm運行程序時出現(xiàn)Run‘python tests for XXX.py‘問題及

    這篇文章主要介紹了pycharm運行程序時出現(xiàn)Run ‘python tests for XXX.py‘問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • Python中Async語法協(xié)程的實現(xiàn)

    Python中Async語法協(xié)程的實現(xiàn)

    這篇文章主要介紹了Python中Async語法協(xié)程的實現(xiàn),文章圍繞主題展開詳細的內容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-06-06
  • Python使用sigthief簽發(fā)證書的實現(xiàn)步驟

    Python使用sigthief簽發(fā)證書的實現(xiàn)步驟

    Windows 系統(tǒng)中的一些非常重要文件通常會被添加數(shù)字簽名,其目的是用來防止被篡改,能確保用戶通過互聯(lián)網下載時能確信此代碼沒有被非法篡改和來源可信,從而保護了代碼的完整性、保護了用戶不會被病毒、惡意代碼和間諜軟件所侵害,本章將演示證書的簽發(fā)與偽造
    2021-06-06
  • 使用Python的數(shù)據(jù)可視化庫Matplotlib實現(xiàn)折線圖

    使用Python的數(shù)據(jù)可視化庫Matplotlib實現(xiàn)折線圖

    數(shù)據(jù)可視化是數(shù)據(jù)分析和探索中不可或缺的一環(huán),本文將介紹如何使用Python中的數(shù)據(jù)可視化庫Matplotlib,通過示例代碼實現(xiàn)一個簡單的折線圖,感興趣的同學可以參考閱讀下
    2023-07-07
  • python3.7安裝matplotlib失敗問題的完美解決方法

    python3.7安裝matplotlib失敗問題的完美解決方法

    由于學習需要安裝matplotlib庫,閱讀網上教程后一直出現(xiàn)各種各樣的錯誤,下面這篇文章主要給大家介紹了關于python3.7安裝matplotlib失敗問題的完美解決方法,需要的朋友可以參考下
    2022-07-07
  • python實現(xiàn)web應用框架之增加動態(tài)路由

    python實現(xiàn)web應用框架之增加動態(tài)路由

    這篇文章主要介紹web應用框架如何添加動態(tài)路由,在我們編寫的框架中,我們添加動態(tài)路由,是使用了正則表達式,同時在注冊的時候,需要注明該路由是請求路由,文中有詳細的代碼示例,需要的朋友可以參考下
    2023-05-05
  • django 中QuerySet特性功能詳解

    django 中QuerySet特性功能詳解

    這篇文章主要介紹了django 中QuerySet特性功能詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-07-07

最新評論