首頁 後端開發 Python教學 python中關於for迴圈的實例詳解

python中關於for迴圈的實例詳解

Jul 02, 2017 am 11:07 AM
python 關於

這篇文章主要介紹了python中關於for循環使用過程中的碎碎念,需要的朋友可以參考下

#為什麼要挑戰自己在程式碼裡不寫for loop?因為這樣可以迫使你去使用比較進階、道地的語法或函式庫。文中以python為例子,講了不少大家其實在別人的程式碼裡都看過、但自己很少用的語法。

這是一個挑戰。我要你避免在任何情況下寫for迴圈。同樣的,我也要你找到一個場景──除了用for迴圈以外,用其他方法寫都太難。請分享你的發現,我非常想聽到這些

距離我開始探索超棒的Python語言特性已經有一段時間了。一開始,這只是我給自己的一個挑戰,練習使用更多的語言特性來取代我從其他程式語言那裡所學到的。但事情漸漸變得更有趣了!程式碼不只變得更簡短整潔,而且看起來更結構化和規律,在這篇文章中我將更多地介紹這些好處。

首先,讓我們退一步看看在寫一個for循環背後的直覺是什麼:

1.遍歷一個序列提取出一些信息

2.從當前的序列中產生另外的序列

3.寫for迴圈已經是我的第二天性了,因為我是一個程式設計師

幸運的是,Python裡面已經有很棒的工具幫你達到這些目標!你需要做的只是轉變思想,用不同的角度看問題。

不到處寫for迴圈你將會得到什麼

1.更少的程式碼行數

2.更好的程式碼閱讀性

# 3.只將縮排用於管理程式碼文字

Let's see the code skeleton below:

#看看下面這段程式碼的架構:


#
# 1
with ...:
  for ...:
    if ...:
      try:
      except:
    else:
登入後複製

這個例子使用了多層嵌套的程式碼,這是非常難以閱讀的。我在這段程式碼中發現它無差別使用縮排把管理邏輯(with, try-except)和業務邏輯(for, if)混在一起。如果你遵守只對管理邏輯使用縮排的規範,那麼核心業務邏輯應該立刻脫離。

「扁平結構比巢狀結構更好」 – 《Python之禪》

#為了避免for循環,你可以使用這些工具

1. 列表解析/生成器表達式

看一個簡單的例子,這個例子主要是根據一個已經存在的序列編譯一個新序列:


result = []
for item in item_list:
  new_item = do_something_with(item)
  result.append(item)
登入後複製

如果你喜歡MapReduce,那你可以用map,或是Python的列表解析:

result = [do_something_with(item) for item in item_list]

同樣的,如果你只是想要取得一個迭代器,你可以使用語法幾乎相通的生成器表達式。 (你怎麼能不愛上Python的一致性?)

result = (do_something_with(item) for item in item_list)

2. 函數

站在更高階、更函數化的變成方式考慮一下,如果你想映射一個序列到另一個序列,直接呼叫map函數。 (也可用列表解析來替代。)

doubled_list = map(lambda x: x * 2, old_list)

如果你想讓一個序列減少到一個元素,使用reduce


from functools import reduce
summation = reduce(lambda x, y: x + y, numbers)
登入後複製

另外,Python中大量的內嵌功能可/會(我不知道這是好事還是壞事,你選一個,不加這個句子有點難懂)消耗迭代器:


>>> a = list(range(10))
>>> a
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> all(a)
False
>>> any(a)
True
>>> max(a)
9
>>> min(a)
0
>>> list(filter(bool, a))
[1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> set(a)
{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}
>>> dict(zip(a,a))
{0: 0, 1: 1, 2: 2, 3: 3, 4: 4, 5: 5, 6: 6, 7: 7, 8: 8, 9: 9}
>>> sorted(a, reverse=True)
[9, 8, 7, 6, 5, 4, 3, 2, 1, 0]
>>> str(a)
'[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]'
>>> sum(a)
45
登入後複製

3. 抽取函數或表達式

上面的兩個方法很好地處理了較為簡單的邏輯,那更複雜的邏輯怎麼辦呢?身為一個程式設計師,我們會把困難的事情抽象化成函數,這種方式也可以用在這裡。如果你寫下了這種程式碼:


results = []
for item in item_list:
  # setups
  # condition
  # processing
  # calculation
  results.append(result)
登入後複製

顯然你賦予了一段程式碼太多的責任。為了改進,我建議你這樣做:


def process_item(item):
  # setups
  # condition
  # processing
  # calculation
  return result

results = [process_item(item) for item in item_list]
登入後複製

嵌套的for迴圈怎麼樣?


results = []
for i in range(10):
  for j in range(i):
    results.append((i, j))
登入後複製

清單解析可以幫助你:


#
results = [(i, j)
      for i in range(10)
      for j in range(i)]
登入後複製

如果你要保存很多的內部狀態怎麼辦?


# finding the max prior to the current item
a = [3, 4, 6, 2, 1, 9, 0, 7, 5, 8]
results = []
current_max = 0
for i in a:
  current_max = max(i, current_max)
  results.append(current_max)

# results = [3, 4, 6, 6, 6, 9, 9, 9, 9, 9]
登入後複製

讓我們提取一個表達式來實現這些:


def max_generator(numbers):
  current_max = 0
  for i in numbers:
    current_max = max(i, current_max)
    yield current_max

a = [3, 4, 6, 2, 1, 9, 0, 7, 5, 8]
results = list(max_generator(a))
登入後複製

「等等,你剛剛在那個函數的表達式中使用了一個for循環,這是欺騙!

4. 你自己不要寫for循環,itertools會為你代勞

這個模組真是妙。我相信這個模組能覆蓋80%你想寫下for循環的時候。例如,上一個例子可以這樣改寫:

from itertools import accumulate
a = [3, 4, 6, 2, 1, 9, 0, 7, 5, 8]
resutls = list(accumulate(a, max))
登入後複製

另外,如果你在迭代組合的序列,還有product(),permutations(),combinations()可以用。

結論

1.大多數情況下是不需要寫for迴圈的。

2.應該避免使用for迴圈,這會讓程式碼有更好的閱讀性。

行動

1.再看一次你的程式碼,找出任何以前憑直覺寫下for循環的地方,再次思考一下,不用for循環再寫一遍是不是有意義的。

2.分享你很難不使用for迴圈的範例。

以上是python中關於for迴圈的實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
4 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

mysql 是否要付費 mysql 是否要付費 Apr 08, 2025 pm 05:36 PM

MySQL 有免費的社區版和收費的企業版。社區版可免費使用和修改,但支持有限,適合穩定性要求不高、技術能力強的應用。企業版提供全面商業支持,適合需要穩定可靠、高性能數據庫且願意為支持買單的應用。選擇版本時考慮的因素包括應用關鍵性、預算和技術技能。沒有完美的選項,只有最合適的方案,需根據具體情況謹慎選擇。

mysql安裝後怎麼使用 mysql安裝後怎麼使用 Apr 08, 2025 am 11:48 AM

文章介紹了MySQL數據庫的上手操作。首先,需安裝MySQL客戶端,如MySQLWorkbench或命令行客戶端。 1.使用mysql-uroot-p命令連接服務器,並使用root賬戶密碼登錄;2.使用CREATEDATABASE創建數據庫,USE選擇數據庫;3.使用CREATETABLE創建表,定義字段及數據類型;4.使用INSERTINTO插入數據,SELECT查詢數據,UPDATE更新數據,DELETE刪除數據。熟練掌握這些步驟,並學習處理常見問題和優化數據庫性能,才能高效使用MySQL。

mySQL下載完安裝不了 mySQL下載完安裝不了 Apr 08, 2025 am 11:24 AM

MySQL安裝失敗的原因主要有:1.權限問題,需以管理員身份運行或使用sudo命令;2.依賴項缺失,需安裝相關開發包;3.端口衝突,需關閉佔用3306端口的程序或修改配置文件;4.安裝包損壞,需重新下載並驗證完整性;5.環境變量配置錯誤,需根據操作系統正確配置環境變量。解決這些問題,仔細檢查每個步驟,就能順利安裝MySQL。

mysql下載文件損壞無法安裝的修復方案 mysql下載文件損壞無法安裝的修復方案 Apr 08, 2025 am 11:21 AM

MySQL下載文件損壞,咋整?哎,下載個MySQL都能遇到文件損壞,這年頭真是不容易啊!這篇文章就來聊聊怎麼解決這個問題,讓大家少走彎路。讀完之後,你不僅能修復損壞的MySQL安裝包,還能對下載和安裝過程有更深入的理解,避免以後再踩坑。先說說為啥下載文件會損壞這原因可多了去了,網絡問題是罪魁禍首,下載過程中斷、網絡不穩定都可能導致文件損壞。還有就是下載源本身的問題,服務器文件本身就壞了,你下載下來當然也是壞的。另外,一些殺毒軟件過度“熱情”的掃描也可能造成文件損壞。診斷問題:確定文件是否真的損壞

mysql 需要互聯網嗎 mysql 需要互聯網嗎 Apr 08, 2025 pm 02:18 PM

MySQL 可在無需網絡連接的情況下運行,進行基本的數據存儲和管理。但是,對於與其他系統交互、遠程訪問或使用高級功能(如復制和集群)的情況,則需要網絡連接。此外,安全措施(如防火牆)、性能優化(選擇合適的網絡連接)和數據備份對於連接到互聯網的 MySQL 數據庫至關重要。

如何針對高負載應用程序優化 MySQL 性能? 如何針對高負載應用程序優化 MySQL 性能? Apr 08, 2025 pm 06:03 PM

MySQL數據庫性能優化指南在資源密集型應用中,MySQL數據庫扮演著至關重要的角色,負責管理海量事務。然而,隨著應用規模的擴大,數據庫性能瓶頸往往成為製約因素。本文將探討一系列行之有效的MySQL性能優化策略,確保您的應用在高負載下依然保持高效響應。我們將結合實際案例,深入講解索引、查詢優化、數據庫設計以及緩存等關鍵技術。 1.數據庫架構設計優化合理的數據庫架構是MySQL性能優化的基石。以下是一些核心原則:選擇合適的數據類型選擇最小的、符合需求的數據類型,既能節省存儲空間,又能提升數據處理速度

MySQL安裝後服務無法啟動的解決辦法 MySQL安裝後服務無法啟動的解決辦法 Apr 08, 2025 am 11:18 AM

MySQL拒啟動?別慌,咱來排查!很多朋友安裝完MySQL後,發現服務死活啟動不了,心裡那個急啊!別急,這篇文章帶你從容應對,揪出幕後黑手!讀完後,你不僅能解決這個問題,還能提升對MySQL服務的理解,以及排查問題的思路,成為一名更強大的數據庫管理員! MySQL服務啟動失敗,原因五花八門,從簡單的配置錯誤到復雜的系統問題都有可能。咱們先從最常見的幾個方面入手。基礎知識:服務啟動流程簡述MySQL服務啟動,簡單來說,就是操作系統加載MySQL相關的文件,然後啟動MySQL守護進程。這其中涉及到配置

mysql安裝後怎麼優化數據庫性能 mysql安裝後怎麼優化數據庫性能 Apr 08, 2025 am 11:36 AM

MySQL性能優化需從安裝配置、索引及查詢優化、監控與調優三個方面入手。 1.安裝後需根據服務器配置調整my.cnf文件,例如innodb_buffer_pool_size參數,並關閉query_cache_size;2.創建合適的索引,避免索引過多,並優化查詢語句,例如使用EXPLAIN命令分析執行計劃;3.利用MySQL自帶監控工具(SHOWPROCESSLIST,SHOWSTATUS)監控數據庫運行狀況,定期備份和整理數據庫。通過這些步驟,持續優化,才能提升MySQL數據庫性能。

See all articles