成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Python中Lambda的前4個錯誤

開發 前端
lambda被認為是非常Python的語言,是Python編程中比較受歡迎的功能之一。 如此之多,以至于許多Python程序員都想盡可能地使用它們。

 

lambda被認為是非常Python的語言,是Python編程中比較受歡迎的功能之一。 如此之多,以至于許多Python程序員都想盡可能地使用它們。

[[320252]]

當然,lambda具有使我們的代碼簡潔的優勢,但是在項目中過度使用它們會導致濫用,從而降低我們代碼的可讀性和可維護性。

在開始研究這些誤用是什么之前,讓我們先快速回顧一下lambda。 如果您對它們非常了解,則可以跳到下一部分。

Lambda,也稱為lambda函數,是匿名函數,可以接受任意數量的參數,而只有一個表達式。 它們的聲明由lambda關鍵字表示。 基本語法如下。

 

  1. lambda arguments: expression 

Lambda最適合需要小的功能且僅使用一次的地方。 lambda的一種常見用法是將其設置為內置sorted()函數中的關鍵參數。 這是一個例子。

 

  1. >>> students = [('Mike''M', 15), ('Mary''F', 14), ('David''M', 16)] 
  2. >>> sorted(students, key=lambda x: x[2]) 
  3. [('Mary''F', 14), ('Mike''M', 15), ('David''M', 16)] 
  4. # The students are sorted by age 

許多教程在解釋lambda是什么以及可以在哪里使用lambda方面做得很好,因此,沒有充分的理由在這里重復大量的講解。

相反,本文的目的是向您展示最常見的lambda誤用,以便在以下所列情況以外的其他情況下使用lambda時,您可能會正確使用它們。

1.重新發明輪子

lambdas的第一個誤用是忽略了現有的內置函數。

讓我們仍然以sorted()函數為例。 假設我們有一個字符串列表,我們想使用它們的長度對它們進行排序。

當然,lambda函數lambda x:len(x)可以工作,但是直接使用內置的len()函數怎么樣?

 

  1. >>> pets = ['dog''turtle''bird''fish''kitty'
  2. >>> sorted(pets, key=lambda x: len(x)) 
  3. ['dog''bird''fish''kitty''turtle'
  4. # The built-in len() function 
  5. >>> sorted(pets, key=len) 
  6. ['dog''bird''fish''kitty''turtle'

這是另一個涉及使用max()函數的示例。

 

  1. >>> number_tuples = [(4, 5, 7), (3, 1, 2), (9, 4, 1)] 
  2. >>> sorted(number_tuples, key=lambda x: max(x)) 
  3. [(3, 1, 2), (4, 5, 7), (9, 4, 1)] 
  4. # The built-in max() function 
  5. >>> sorted(number_tuples, key=max
  6. [(3, 1, 2), (4, 5, 7), (9, 4, 1)] 

優秀實踐1:在編寫自己的Lambda之前先考慮一下內置函數。

2.將其分配給變量

在一些教程(包括我的一些教程)中,我已經看到了將lambdas分配給變量的方法,但是它主要是向初學者展示lambdas本質上是函數。

但是,某些初學者可能已將其作為一種好習慣,并認為lambda只是聲明短函數的便捷方式。 以下代碼片段向您展示了這種濫用。

 

  1. >>> divide_two_numbers = lambda x, y: x / y 
  2. >>> divide_two_numbers(4, 5) 
  3. 0.8 

為什么要避免這種情況? 如果您還記得上面提到的內容,那么lambda應該只使用一次,因此沒有理由將lambda分配給變量。

如果確實需要使用相關功能,則應使用def關鍵字來聲明一個常規函數,如下所示。

如果您認為使用此簡單功能的兩行代碼并不酷,我們可以將其重寫為一行:defdivid_two_numbers_fun(x,y):返回x / y,其工作方式相同。

 

  1. >>> def divide_two_numbers_fun(x,y):  
  2. ...     return x / y 
  3. ...  
  4. >>> divide_two_numbers_fun(7, 8) 
  5. 0.875 

避免為變量分配lambda的主要原因是出于調試/維護的目的,尤其是在生產/團隊合作環境中。

讓我們看一個簡單的例子,可能發生的事情。 在實際情況下,事情可能會變得復雜得多。

 

  1. >>> divide_two_numbers(3, 0) 
  2. Traceback (most recent call last): 
  3.   File "<stdin>", line 1, in <module> 
  4.   File "<stdin>", line 1, in <lambda> 
  5. ZeroDivisionError: division by zero 
  6. >>> divide_two_numbers_fun(3, 0) 
  7. Traceback (most recent call last): 
  8.   File "<stdin>", line 1, in <module> 
  9.   File "<stdin>", line 1, in divide_two_numbers_fun 
  10. ZeroDivisionError: division by zero 

如您在上面看到的,通過常規函數的聲明,我們確切地知道哪個函數導致了錯誤。 相比之下,使用lambda只能告訴我們存在一個lambda導致錯誤。

為什么沒有顯示功能名稱?

這是因為lambda是匿名函數,所有這些函數都具有相同的名稱-。 您能想象如果您的同事發現數十個存在錯誤會多么令人沮喪?

優秀實踐2:要多次使用常規函數而不是lambda。

3.高階函數使用不當

當我們說高階函數時,是指可以通過將函數作為參數或通過返回函數來對其他函數進行操作的函數。

與當前主題相關的函數是map(),filter()和reduce(),它們在lambda的許多教程中都已或多或少地被使用。 但是,這導致對lambda以及更高階函數的某種濫用。

出于演示目的,我將在本教程中僅使用map()函數,但相同的原理也適用于其他高階函數。

假設我們有一個整數列表,并且希望有一個包含它們的平方的列表。 下面將lambda與map()函數一起使用。

我們將獲得一個迭代器-map()函數中的map對象,然后將其轉換為列表,我們需要在此迭代器上調用list()函數。

 

  1. >>> numbers = [1, 2, 3, 5, 8] 
  2. >>> squares = list(map(lambda x: x * x, numbers)) 
  3. >>> squares 
  4. [1, 4, 9, 25, 64] 

實際上,可以通過列表理解方便地實現相同的功能-不需要高階函數或lambda。 更加簡潔易讀,不是嗎?

當然,掌握列表理解能力是另一個" Pythonic功能"主題,需要另一個教程。

 

  1. >>> numbers = [1, 2, 3, 5, 8] 
  2. >>> squares = [x * x for x in numbers] 
  3. >>> squares 
  4. [1, 4, 9, 25, 64] 

優秀實踐3:考慮使用帶列表推導的lambda替換高階函數。

4.表達式太笨拙

這比以前的方法少見。 但是一些程序員只是盡可能地使用lambda來努力編寫最多的Python代碼。 有時需要付出一定的代價-可讀性。

假設我們有一個字符串列表,我們需要使用一個奇怪的要求對它們進行排序:單詞中不同元音的數量。 在sorted()函數中使用lambda如下所示。

 

  1. >>> texts = ['iiiii''bag''beto''blackboard''sequoia'
  2. >>> sorted(texts, key=lambda x: len(set([l for l in list(x) if l in ['a','e','i','o','u']]))) 
  3. ['iiiii''bag''beto''blackboard''sequoia'

它可以按預期工作,但絕對不是最易讀的代碼。 下面的代碼怎么樣?

 

  1. >>> texts = ['iiiii''bag''beto''blackboard''sequoia'
  2. >>> def number_distinct_vowels(x): 
  3. ...     vowels = ['a''e''i''o''u'
  4. ...     vowels_only = [l for l in list(x) if l in vowels] 
  5. ...     distinct_vowels = set(all_vowels) 
  6. ...     return len(distinct_vowels) 
  7. ...  
  8. >>> sorted(texts, key=number_distinct_vowels) 
  9. ['iiiii''bag''beto''blackboard''sequoia'

當然,我們需要再寫幾行代碼,但是新代碼難道不具有更好的可讀性嗎?

 優秀實踐4:如果lambda的表達式過于繁瑣,則編寫一個正則函數。

總結

Lambda一直是Python初學者的硬主題之一,他們一開始就不惜一切代價避免使用它們。

一段時間后,當恐懼消失時,他們開始學習lambda,并發現自己一點也不難。 然后,它們開始使用lambda,但不幸的是,有些人可能過多地使用了lambda,導致如上所述的各種濫用。

我希望本文可以幫助解決其中一些問題。

通過避免這些誤用并遵循優秀實踐技巧,我敢打賭,正確使用lambda的Python代碼將具有更好的可讀性和可維護性。

責任編輯:華軒 來源: 今日頭條
相關推薦

2025-01-15 07:00:00

Java代碼Lambda

2021-09-13 07:53:31

Go錯誤處理

2020-05-06 15:15:33

Python開發工具

2024-09-23 16:49:32

2022-06-27 08:36:08

PythonLambda

2020-03-20 15:10:09

Python錯誤分析代碼

2020-09-17 11:08:53

GitHubPython倉庫

2010-03-17 13:46:55

Python sock

2024-05-30 14:21:00

lambdaPython代碼

2024-04-28 11:36:07

LambdaPython函數

2024-06-24 10:00:00

Python編程

2025-02-10 00:00:00

技巧JavaStreams

2024-10-07 08:26:05

編程Python異常處理

2009-06-22 10:34:43

Boost庫lambda

2013-01-20 14:54:34

PythonLambda

2024-01-31 13:50:00

系統設計系統

2020-08-16 12:38:32

Python算法編程

2010-07-19 12:54:16

SQL Server安

2009-01-16 22:19:58

服務器虛擬化

2020-11-06 08:30:45

數據分析數據思維錯誤
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 青青久久久| 国产视频1区 | 天堂中文在线观看 | 天堂免费看片 | aaaaaa大片免费看最大的 | 国产精品久久久久久久久久久免费看 | 成人在线视频免费看 | 久久大全 | 精品日韩 | 亚洲欧美日本在线 | 国产欧美一区二区三区日本久久久 | 不卡一区二区三区四区 | 日本午夜在线视频 | 欧美日韩三级 | 男女性毛片 | 亚洲日本一区二区 | 在线观看av不卡 | 伊人伊人 | 欧美国产一区二区三区 | 北条麻妃一区二区三区在线观看 | 午夜精品一区二区三区在线观看 | 国产精品一区一区三区 | 性一交一乱一透一a级 | 自拍偷拍欧美 | 欧美一区二区三区四区视频 | 久久精品一区 | 亚洲网站免费看 | 国产亚洲一区二区三区 | 自拍偷拍中文字幕 | 国产麻豆乱码精品一区二区三区 | 一级爱爱片 | 狠狠操在线| 日本激情视频在线播放 | 中文字字幕在线中文乱码范文 | 日韩资源 | 一区中文字幕 | 亚洲毛片网站 | 国产大毛片 | 国产精品一区二区视频 | 欧美偷偷| 久草成人网 |