av激情亚洲男人的天堂国语,日韩欧美精品一中文字幕,无码av一区二区三区无码,国产又色又爽又刺激的a片,国产又色又爽又刺激的a片

經(jīng)驗豐富程序員才知道的8種高級Python技巧

本文轉(zhuǎn)載自公眾號“讀芯術”(ID:AI_Discovery)

成都創(chuàng)新互聯(lián)是一家專注于成都網(wǎng)站制作、做網(wǎng)站、外貿(mào)營銷網(wǎng)站建設與策劃設計,清水河網(wǎng)站建設哪家好?成都創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設十余年,網(wǎng)設計領域的專業(yè)建站公司;建站業(yè)務涵蓋:清水河等地區(qū)。清水河做網(wǎng)站價格咨詢:18980820575

 本文將介紹8個簡潔的Python技巧,若非經(jīng)驗十足的程序員,你肯定有些從未見過。向著更簡潔更高效,出發(fā)吧!

1.通過多個鍵值將對象進行排序

假設要對以下字典列表進行排序:

 
 
 
 
  1. people = [ 
  2. { 'name': 'John', "age": 64 }, 
  3. { 'name': 'Janet', "age": 34 }, 
  4. { 'name': 'Ed', "age": 24 }, 
  5. { 'name': 'Sara', "age": 64 }, 
  6. { 'name': 'John', "age": 32 }, 
  7. { 'name': 'Jane', "age": 34 }, 
  8. { 'name': 'John', "age": 99 }, 

不僅要按名字或年齡對其進行排序,還要將兩個字段同時進行排序。在SQL中,會是這樣的查詢:

 
 
 
 
  1. SELECT * FROM people ORDER by name, age 

實際上,這個問題的解決方法可以非常簡單,Python保證sort函數(shù)提供了穩(wěn)定的排序順序,這也意味著比較相似的項將保留其原始順序。要實現(xiàn)按名字和年齡排序,可以這樣做:

 
 
 
 
  1. import operator 
  2. people.sort(key=operator.itemgetter('age')) 
  3. people.sort(key=operator.itemgetter('name')) 

要注意如何反轉(zhuǎn)順序。首先按年齡分類,然后按名字分類,使用operator.itemgetter()從列表中的每個字典中獲取年齡和名字字段,這樣你就會得到想要的結果:

 
 
 
 
  1. {'name': 'Ed', 'age': 24}, 
  2. {'name': 'Jane', 'age': 34}, 
  3. {'name': 'Janet','age': 34}, 
  4. {'name': 'John', 'age': 32}, 
  5. {'name': 'John', 'age': 64}, 
  6. {'name': 'John', 'age': 99}, 
  7. {'name': 'Sara', 'age': 64} 

名字是主要排序項,如果姓名相同,則以年齡排序。因此,所有John都按年齡分組在一起。

2.數(shù)據(jù)類別

自3.7版之后,Python開始能提供數(shù)據(jù)類別。比起常規(guī)類或其他替代方法(如返回多個值或字典),它有著更多優(yōu)點:

  • 數(shù)據(jù)類需要很少的代碼
  • 可以比較數(shù)據(jù)類,因為 __eq__ 可以實現(xiàn)此功能
  • 數(shù)據(jù)類需要類型提示,減少了發(fā)生錯誤的可能性
  • 可以輕松打印數(shù)據(jù)類以進行調(diào)試,因為__repr__可以實現(xiàn)此功能

這是一個工作中的數(shù)據(jù)類示例:

 
 
 
 
  1. from dataclasses import dataclass 
  2.                   @dataclass 
  3.                  classCard: 
  4.                      rank: str 
  5.                      suit: str 
  6.                        card=Card("Q", "hearts") 
  7.                   print(card == card) 
  8.                  # True 
  9.                   print(card.rank) 
  10.                  # 'Q' 
  11.                   print(card) 
  12.                  Card(rank='Q', suit='hearts') 

3.列表推導

列表推導可以在列表填寫里代替討厭的循環(huán),其基本語法為

 
 
 
 
  1. [ expression for item in list if conditional ] 

來看一個非?;镜氖纠?,用數(shù)字序列填充列表:

 
 
 
 
  1. mylist = [i for i inrange(10)] 
  2.                 print(mylist) 
  3.                 # [0, 1, 2, 3,4, 5, 6, 7, 8, 9] 

因為可以使用表達式,所以你還可以進行一些數(shù)學運算:

 
 
 
 
  1. squares = [x**2for x inrange(10)] 
  2.                 print(squares) 
  3.                 # [0, 1, 4, 9,16, 25, 36, 49, 64, 81] 

甚至能調(diào)用外部函數(shù):

 
 
 
 
  1. defsome_function(a): 
  2.                                 return (a +5) /2 
  3.                                 
  4.                             my_formula= [some_function(i) for i inrange(10)] 
  5.                             print(my_formula) 
  6.                             # [2.5, 3.0,3.5, 4.0, 4.5, 5.0, 5.5, 6.0, 6.5, 7.0] 

最后,可以使用if函數(shù)來篩選列表。在這種情況下,只保留可被2除的值:

 
 
 
 
  1. filtered = [i for i inrange(20) if i%2==0] 
  2.                print(filtered) 
  3.                # [0, 2, 4, 6,8, 10, 12, 14, 16, 18] 

4.檢查對象的內(nèi)存使用情況

使用sys.getsizeof()可以檢查對象的內(nèi)存使用情況:

 
 
 
 
  1. import sys 
  2.                   mylist =range(0, 10000) 
  3.           print(sys.getsizeof(mylist)) 
  4.           # 48 

為什么這個龐大的列表只有48個字節(jié)?這是因為range函數(shù)返回的類表現(xiàn)為列表。與使用實際的數(shù)字列表相比,數(shù)序列的存儲效率要高得多。我們可以通過列表推導來創(chuàng)建相同范圍內(nèi)的實際數(shù)字列表:

 
 
 
 
  1. import sys 
  2.                   myreallist = [x for x inrange(0, 10000)] 
  3.           print(sys.getsizeof(myreallist)) 
  4.           # 87632 

通過使用sys.getsizeof(),我們可以了解更多關于Python和內(nèi)存使用情況的信息。

5.查找最頻繁出現(xiàn)的值

要查找列表或字符串中最頻繁出現(xiàn)的值:

 
 
 
 
  1. test = [1, 2, 3, 4, 2, 2, 3, 1, 4, 4, 4] 
  2.      print(max(set(test), key = test.count)) 
  3.      # 4 
  • max()將返回列表中的最大值。key參數(shù)采用單個參數(shù)函數(shù)自定義排序順序,在本例中為test.count,該函數(shù)適用于迭代器上的每個項目。
  • test.count是list的內(nèi)置功能。它接受一個參數(shù),并計算該參數(shù)的出現(xiàn)次數(shù)。因此test.count(1)將返回2,而test.count(4)將返回4。
  • set(test)返回test中的所有唯一值,所以{1、2、3、4}

那么在這一行代碼將接受test的所有唯一值,即{1、2、3、4}。接下來,max將對其應用list.count 函數(shù)并返回最大值。

還有一種更有效的方法:

 
 
 
 
  1. from collections import Counter 
  2. Counter(test).most_common(1) 
  3. # [4: 4] 

6.屬性包

你可以使用attrs代替數(shù)據(jù)類,選擇attrs有兩個原因:

  • 使用的Python版本高于3.7
  • 想要更多功能

Theattrs軟件包支持所有主流Python版本,包括CPython 2.7和PyPy。一些attrs可以提供驗證器和轉(zhuǎn)換器這種超常規(guī)數(shù)據(jù)類。來看一些示例代碼:

 
 
 
 
  1. @attrs 
  2.           classPerson(object): 
  3.               name =attrib(default='John') 
  4.               surname =attrib(default='Doe') 
  5.               age =attrib(init=False) 
  6.               p =Person() 
  7.           print(p) 
  8.           p=Person('Bill', 'Gates') 
  9.           p.age=60 
  10.           print(p) 
  11.                   # Output: 
  12.           #   Person(name='John', surname='Doe',age=NOTHING) 
  13.           #   Person(name='Bill', surname='Gates', age=60) 

實際上,attrs的作者已經(jīng)在使用引入數(shù)據(jù)類的PEP了。數(shù)據(jù)類被有意地保持得更簡單、更容易理解,而attrs 提供了可能需要的所有特性。

7.合并字典(Python3.5+)

 
 
 
 
  1. dict1 = { 'a': 1, 'b': 2 } 
  2.         dict2= { 'b': 3, 'c': 4 } 
  3.         merged= { **dict1, **dict2 } 
  4.         print (merged) 
  5.         # {'a': 1, 'b':3, 'c': 4} 

如果有重疊的鍵,第一個字典中的鍵將被覆蓋。在Python 3.9中,合并字典變得更加簡潔。上面Python 3.9中的合并可以重寫為:

 
 
 
 
  1. merged = dict1 | dict2 

8.返回多個值

Python中的函數(shù)在沒有字典,列表和類的情況下可以返回多個變量,它的工作方式如下:

 
 
 
 
  1. defget_user(id): 
  2.                        # fetch user from database 
  3.                        # .... 
  4.                        return name, birthdate 
  5.                   name, birthdate =get_user(4) 

這是有限的返回值,但任何超過3個值的內(nèi)容都應放入一個(數(shù)據(jù))類。

這8個小技巧足夠你好好消化一陣兒啦!


分享文章:經(jīng)驗豐富程序員才知道的8種高級Python技巧
文章分享:http://uogjgqi.cn/article/dpesjje.html

掃二維碼與項目經(jīng)理溝通

我們在微信上24小時期待你的聲音

解答本文疑問/技術咨詢/運營咨詢/技術建議/互聯(lián)網(wǎng)交流