導航:首頁 > 編程語言 > python訓練技巧

python訓練技巧

發布時間:2023-06-02 15:43:36

『壹』 python編程常用技巧

鏈接:https://pan..com/s/1Nb7euy7yqFQqALbBgKzlVw

提取碼:dfsm

Python 編程高手之路。本課程分五個階段,詳細的為您打造高手之路,本課程適合有一定python基礎的同學。

用Python可以做什麼?可以做日常任務,比如自動備份你的MP3;可以做網站,很多著名的網站就是Python寫的。總之就是能幹很多很多事。

課程目錄:

第一階段

第一章:用戶交互

第二章:流程式控制制

第三章:數據類型

第四章:字元編碼

第五章:文件處理

第二階段

第六章:函數概述

第七章:閉包函數

......

『貳』 「干貨」讓Python性能起飛的15個技巧,你知道幾個呢

前言

Python 一直以來被大家所詬病的一點就是執行速度慢,但不可否認的是 Python 依然是我們學習和工作中的一大利器。本文總結了15個tips有助於提升 Python 執行速度、優化性能。

關於 Python 如何精確地測量程序的執行時間,這個問題看起來簡單其實很復雜,因為程序的執行時間受到很多因素的影響,例如操作系統、Python 版本以及相關硬體(CPU 性能、內存讀寫速度)等。在同一台電腦上運行相同版本的語言時,上述因素就是確定的了,但是程序的睡眠時間依然是變化的,且電腦上正在運行的其他程序也會對實驗有干擾,因此嚴格來說這就是實驗不可重復。

我了解到的關於計時比較有代表性的兩個庫就是 time 和 timeit 。

其中, time 庫中有 time() 、 perf_counter() 以及 process_time() 三個函數可用來計時(以秒為單位),加後綴 _ns 表示以納秒計時(自 Python3.7 始)。在此之前還有 clock() 函數,但是在 Python3.3 之後被移除了。上述三者的區別如下:

與 time 庫相比, timeit 有兩個優點:

timeit.timeit(stmt='pass', setup='pass', timer= , number=1000000, globals=None) 參數說明:

本文所有的計時均採用 timeit 方法,且採用默認的執行次數一百萬次。

為什麼要執行一百萬次呢?因為我們的測試程序很短,如果不執行這么多次的話,根本看不出差距。

Exp1:將字元串數組中的小寫字母轉為大寫字母。

測試數組為 oldlist = ['life', 'is', 'short', 'i', 'choose', 'python']。

方法一

方法二

方法一耗時 0.5267724000000005s ,方法二耗時 0.41462569999999843s ,性能提升 21.29%

Exp2:求兩個 list 的交集。

測試數組:a = [1,2,3,4,5],b = [2,4,6,8,10]。

方法一

方法二

方法一耗時 0.9507264000000006s ,方法二耗時 0.6148200999999993s ,性能提升 35.33%

關於 set() 的語法: | 、 & 、 - 分別表示求並集、交集、差集。

我們可以通過多種方式對序列進行排序,但其實自己編寫排序演算法的方法有些得不償失。因為內置的 sort() 或 sorted() 方法已經足夠優秀了,且利用參數 key 可以實現不同的功能,非常靈活。二者的區別是 sort() 方法僅被定義在 list 中,而 sorted() 是全局方法對所有的可迭代序列都有效。

Exp3:分別使用快排和 sort() 方法對同一列表排序。

測試數組:lists = [2,1,4,3,0]。

方法一

方法二

方法一耗時 2.4796975000000003s ,方法二耗時 0.05551999999999424s ,性能提升 97.76%

順帶一提, sorted() 方法耗時 0.1339823999987857s

可以看出, sort() 作為 list 專屬的排序方法還是很強的, sorted() 雖然比前者慢一點,但是勝在它「不挑食」,它對所有的可迭代序列都有效。

擴展 :如何定義 sort() 或 sorted() 方法的 key

1.通過 lambda 定義

2.通過 operator 定義

operator 的 itemgetter() 適用於普通數組排序, attrgetter() 適用於對象數組排序

3.通過 cmp_to_key() 定義,最為靈活

Exp4:統計字元串中每個字元出現的次數。

測試數組:sentence='life is short, i choose python'。

方法一

方法二

方法一耗時 2.8105250000000055s ,方法二耗時 1.6317423000000062s ,性能提升 41.94%

列表推導(list comprehension)短小精悍。在小代碼片段中,可能沒有太大的區別。但是在大型開發中,它可以節省一些時間。

Exp5:對列表中的奇數求平方,偶數不變。

測試數組:oldlist = range(10)。

方法一

方法二

方法一耗時 1.5342976000000021s ,方法二耗時 1.4181957999999923s ,性能提升 7.57%

大多數人都習慣使用 + 來連接字元串。但其實,這種方法非常低效。因為, + 操作在每一步中都會創建一個新字元串並復制舊字元串。更好的方法是用 join() 來連接字元串。關於字元串的其他操作,也盡量使用內置函數,如 isalpha() 、 isdigit() 、 startswith() 、 endswith() 等。

Exp6:將字元串列表中的元素連接起來。

測試數組:oldlist = ['life', 'is', 'short', 'i', 'choose', 'python']。

方法一

方法二

方法一耗時 0.27489080000000854s ,方法二耗時 0.08166570000000206s ,性能提升 70.29%

join 還有一個非常舒服的點,就是它可以指定連接的分隔符,舉個例子

life//is//short//i//choose//python

Exp6:交換x,y的值。

測試數據:x, y = 100, 200。

方法一

方法二

方法一耗時 0.027853900000010867s ,方法二耗時 0.02398730000000171s ,性能提升 13.88%

在不知道確切的循環次數時,常規方法是使用 while True 進行無限循環,在代碼塊中判斷是否滿足循環終止條件。雖然這樣做沒有任何問題,但 while 1 的執行速度比 while True 更快。因為它是一種數值轉換,可以更快地生成輸出。

Exp8:分別用 while 1 和 while True 循環 100 次。

方法一

方法二

方法一耗時 3.679268300000004s ,方法二耗時 3.607847499999991s ,性能提升 1.94%

將文件存儲在高速緩存中有助於快速恢復功能。Python 支持裝飾器緩存,該緩存在內存中維護特定類型的緩存,以實現最佳軟體驅動速度。我們使用 lru_cache 裝飾器來為斐波那契函數提供緩存功能,在使用 fibonacci 遞歸函數時,存在大量的重復計算,例如 fibonacci(1) 、 fibonacci(2) 就運行了很多次。而在使用了 lru_cache 後,所有的重復計算只會執行一次,從而大大提高程序的執行效率。

Exp9:求斐波那契數列。

測試數據:fibonacci(7)。

方法一

方法二

方法一耗時 3.955014900000009s ,方法二耗時 0.05077979999998661s ,性能提升 98.72%

注意事項:

我被執行了(執行了兩次 demo(1, 2) ,卻只輸出一次)

functools.lru_cache(maxsize=128, typed=False) 的兩個可選參數:

點運算符( . )用來訪問對象的屬性或方法,這會引起程序使用 __getattribute__() 和 __getattr__() 進行字典查找,從而帶來不必要的開銷。尤其注意,在循環當中,更要減少點運算符的使用,應該將它移到循環外處理。

這啟發我們應該盡量使用 from ... import ... 這種方式來導包,而不是在需要使用某方法時通過點運算符來獲取。其實不光是點運算符,其他很多不必要的運算我們都盡量移到循環外處理。

Exp10:將字元串數組中的小寫字母轉為大寫字母。

測試數組為 oldlist = ['life', 'is', 'short', 'i', 'choose', 'python']。

方法一

方法二

方法一耗時 0.7235491999999795s ,方法二耗時 0.5475435999999831s ,性能提升 24.33%

當我們知道具體要循環多少次時,使用 for 循環比使用 while 循環更好。

Exp12:使用 for 和 while 分別循環 100 次。

方法一

方法二

方法一耗時 3.894683299999997s ,方法二耗時 1.0198077999999953s ,性能提升 73.82%

Numba 可以將 Python 函數編譯碼為機器碼執行,大大提高代碼執行速度,甚至可以接近 C 或 FORTRAN 的速度。它能和 Numpy 配合使用,在 for 循環中或存在大量計算時能顯著地提高執行效率。

Exp12:求從 1 加到 100 的和。

方法一

方法二

方法一耗時 3.7199997000000167s ,方法二耗時 0.23769430000001535s ,性能提升 93.61%

矢量化是 NumPy 中的一種強大功能,可以將操作表達為在整個數組上而不是在各個元素上發生。這種用數組表達式替換顯式循環的做法通常稱為矢量化。

在 Python 中循環數組或任何數據結構時,會涉及很多開銷。NumPy 中的向量化操作將內部循環委託給高度優化的 C 和 Fortran 函數,從而使 Python 代碼更加快速。

Exp13:兩個長度相同的序列逐元素相乘。

測試數組:a = [1,2,3,4,5], b = [2,4,6,8,10]

方法一

方法二

方法一耗時 0.6706845000000214s ,方法二耗時 0.3070132000000001s ,性能提升 54.22%

若要檢查列表中是否包含某成員,通常使用 in 關鍵字更快。

Exp14:檢查列表中是否包含某成員。

測試數組:lists = ['life', 'is', 'short', 'i', 'choose', 'python']

方法一

方法二

方法一耗時 0.16038449999999216s ,方法二耗時 0.04139250000000061s ,性能提升 74.19%

itertools 是用來操作迭代器的一個模塊,其函數主要可以分為三類:無限迭代器、有限迭代器、組合迭代器。

Exp15:返回列表的全排列。

測試數組:["Alice", "Bob", "Carol"]

方法一

方法二

方法一耗時 3.867292899999484s ,方法二耗時 0.3875405000007959s ,性能提升 89.98%

根據上面的測試數據,我繪制了下面這張實驗結果圖,可以更加直觀的看出不同方法帶來的性能差異。

從圖中可以看出,大部分的技巧所帶來的性能增幅還是比較可觀的,但也有少部分技巧的增幅較小(例如編號5、7、8,其中,第 8 條的兩種方法幾乎沒有差異)。

總結下來,我覺得其實就是下面這兩條原則:

內置庫函數由專業的開發人員編寫並經過了多次測試,很多庫函數的底層是用 C 語言開發的。因此,這些函數總體來說是非常高效的(比如 sort() 、 join() 等),自己編寫的方法很難超越它們,還不如省省功夫,不要重復造輪子了,何況你造的輪子可能更差。所以,如果函數庫中已經存在該函數,就直接拿來用。

有很多優秀的第三方庫,它們的底層可能是用 C 和 Fortran 來實現的,像這樣的庫用起來絕對不會吃虧,比如前文提到的 Numpy 和 Numba,它們帶來的提升都是非常驚人的。類似這樣的庫還有很多,比如Cython、PyPy等,這里我只是拋磚引玉。

原文鏈接:https://www.jb51.net/article/238190.htm

『叄』 如何系統地自學Python你知道哪些相關的學習小技巧

Python即計算機高級編程語言,能夠簡單有效的面向對象編程,它的本質就是ABC語言的替代品,想要自學就要先學會編程,在基礎入門時,就需要對自己有一個清醒的認知,掌握編程語言,要能夠看得懂復雜的編程代碼,清楚自己學習編程的目標,朝著既定目標前進,嘗試收集一些相關資料,建立牢固的編程思維,在看到無法理解的代碼時,可以選擇輔助工具幫忙理解。

想要更好地學習Python編程技術,就像學生學習那樣進行刷題,鞏固所學知識,提高編程效率,遇到困難時,不輕言放棄,遇到程序錯誤和異常時,多查找原因,詢問前輩,積極動手實踐解決,總的來說,就是要多學多看多練,學習Python編程技術,從來都不是一蹴而就的,要努力堅持下去,最後,不要為了學習一門編程語言而去學習,從始至終不要忘記自己學習Python編程的目標。

『肆』 IT培訓分享新手程序員學習python編程需要了解哪些技巧

python編程開發技術是目前比較熱門的編程語言之一了,而對於大多數新接觸python編程的程序員來說,如果能夠掌握一定的編程技巧的話會大大降低我們掌握python編程的難度,下面IT培訓http://www.kmbdqn.com/就一起來了解一下具體內容吧。



建議1:理解Pythonic概念


建議2:編寫Pythonic代碼


建議3:理解Python與C語言的不同之處


建議4:在代碼中適當添加註釋


建議5:通過適當添加空行使代碼布局更為優雅、合理


建議6:編寫函數的4個原則


建議7:將常量集中到一個文件


建議8:利用assert語句來發現問題


建議9:數據交換值的時候不推薦使用中間變數


建議10:充分利用Lazyevaluation的特性


建議11:理解枚舉替代實現的缺陷


建議12:不推薦使用type來進行類型檢查


建議13:盡量轉換為浮點類型後再做除法


建議14:警惕eval()的安全漏洞


建議15:使用enumerate()獲取序列迭代的索引和值


建議16:分清=與is的適用場景


建議17:考慮兼容性,盡可能使用Unicode


建議18:構建合理的包層次來管理mole


建議19:有節制地使用fromimport語句


建議20:優先使用absoluteimport來導入模塊


建議21:i+=1不等於++i


建議22:使用with自動關閉資源


建議23:使用else子句簡化循環(異常處理)


建議24:遵循異常處理的幾點基本原則


建議25:避免finally中可能發生的陷阱


建議26:深人理解None,正確判斷對象是否為空


建議27:連接字元串應優先使用join而不是+


建議28:格式化字元串時盡量使用.format方式而不是%


建議29:區別對待可變對象和不可變對象


建議30:[]、()和{}:一致的容器初始化形式


建議31:記住函數傳參既不是傳值也不是傳引用


建議32:警惕默認參數潛在的問題


建議33:慎用變長參數


建議34:深入理解str()和repr()的區別


『伍』 優化Python編程的4個妙招

1. Pandas.apply() – 特徵工程瑰寶



Pandas 庫已經非常優化了,但是大部分人都沒有發揮它的最大作用。想想它一般會用於數據科學項目中的哪些地方。一般首先能想到的就是特徵工程,即用已有特徵創造新特徵。其中最高效的方法之一就是Pandas.apply(),即Pandas中的apply函數。



在Pandas.apply()中,可以傳遞用戶定義功能並將其應用到Pandas Series的所有數據點中。這個函數是Pandas庫最好的擴展功能之一,它能根據所需條件分隔數據。之後便能將其有效應用到數據處理任務中。



2. Pandas.DataFrame.loc – Python數據操作絕妙技巧



所有和數據處理打交道的數據科學家(差不多所有人了!)都應該學會這個方法。



很多時候,數據科學家需要根據一些條件更新數據集中某列的某些值。Pandas.DataFrame.loc就是此類問題最優的解決方法。



3. Python函數向量化



另一種解決緩慢循環的方法就是將函數向量化。這意味著新建函數會應用於輸入列表,並返回結果數組。在Python中使用向量化能至少迭代兩次,從而加速計算。



事實上,這樣不僅能加速代碼運算,還能讓代碼更加簡潔清晰。



4. Python多重處理



多重處理能使系統同時支持一個以上的處理器。



此處將數據處理分成多個任務,讓它們各自獨立運行。處理龐大的數據集時,即使是apply函數也顯得有些遲緩。



關於優化Python編程的4個妙招,青藤小編就和您分享到這里了。如果您對python編程有濃厚的興趣,希望這篇文章可以為您提供幫助。如果您還想了解更多關於python編程的技巧及素材等內容,可以點擊本站的其他文章進行學習。

閱讀全文

與python訓練技巧相關的資料

熱點內容
pdf轉換器軟體 瀏覽:639
命令提示符的雙引號 瀏覽:184
命令行運行編譯器 瀏覽:547
linux升級php7 瀏覽:123
love法國原版電影 瀏覽:62
什麼app不用驗證手機登錄 瀏覽:481
python抓包http 瀏覽:893
安卓手機如何屏蔽黃色內容 瀏覽:176
有損壓縮失真嗎 瀏覽:412
法國經典復古四級有哪些 瀏覽:598
帶英文字幕的中文電影 瀏覽:899
泰國百合劇大全 瀏覽:506
甲骨文雲伺服器流量 瀏覽:222
程序員不那麼程序員都么可愛 瀏覽:535
惠普文件夾怎麼加密 瀏覽:744
沐風之女在線觀看 瀏覽:715
術後pdf 瀏覽:497
免費看的韓國電影劇情片 瀏覽:120
單片機sck 瀏覽:829
絕佳江山一攻多受 瀏覽:954