自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

分享九個一般人不知道的Python好用技巧

開發(fā) 后端
本篇分享是Python生態(tài)系統(tǒng)中關(guān)于一些有用的技巧。大多數(shù)技巧只是使用標準庫中的包,但其他一些技巧會涉及一些第三方包。

本篇分享是Python生態(tài)系統(tǒng)中關(guān)于一些有用的技巧。大多數(shù)技巧只是使用標準庫中的包,但其他一些技巧會涉及一些第三方包。

在開始閱讀本文內(nèi)容之前,我們首先來回顧一下Python中的Iterables的概念。

[[440277]]

根據(jù)Python標準文檔,Iterable的概念如下:

  • 一種能夠一次返回一個成員的對象。

iterables的示例包括:

  • 所有序列類型(如list、str和tuple)
  • 一些非序列類型,如dict、文件對象以及類的實現(xiàn)中定義了__iter__()方法

Iterables是一個需要我們牢記的概念,因為接下來我們展示的許多技巧都使用itertools包。

itertools模塊提供了一些函數(shù),用于接收Iterable對象,而不僅僅是打印逐個對象。

2.Trick 1

在工作學習中,我們經(jīng)常會需要使用一個簡單的函數(shù)來實現(xiàn)從一個list來生成新的list,set或dict.此時我們就會用到iterables概念。

舉例來說:

生成List: 

  1. names = ['John''Bard''Jessica' 'Andres'
  2. lower_names = [name.lower() for name in names] 

生成Set: 

  1. names = ['John''Bard''Jessica' 'Andres'
  2. lower_names = { 
  3.  name.lower() for name in names} 

生成Dict: 

  1. names = ['John''Bard''Jessica' 'Andres'
  2. lower_names = { 
  3.  name:name.lower() for name in names} 

個人建議:

僅當for語句、函數(shù)調(diào)用和方法調(diào)用的數(shù)量較少時使用。

3.Trick 2

有時,我們需要獲得兩個列表對象之間的所有可能組合。

我們首先想到的實現(xiàn)可能如下: 

  1. l1 = [1, 2, 3] 
  2. l2 = [4, 5, 6] 
  3. combinations = [] 
  4. for e1 in l1: 
  5.   for e2 in l2: 
  6.     combinations.append((e1, e2)) 

或者簡化一下,如下:

  1. combinations = [(e1, e2) for e1 in l1 for e2 in l1] 

上述實現(xiàn)已經(jīng)很簡潔了,但標準庫itertools提供product函數(shù),從而提供了相同的結(jié)果。如下所示: 

  1. from itertools import product 
  2. l1 = [1, 2, 3] 
  3. l2 = [4, 5, 6] 
  4. combinatios = product(l1, l2) 

4.Trick3

假設有一個元素列表,我們需要在每對相鄰元素之間比較或應用一些操作,這有時稱為2個元素的滑動窗口。我們可以采用以下方式: 

  1. from itertools import tee 
  2. from typing import Iterable 
  3.  
  4. def window2(iterable: Iterable): 
  5.   it, offset = tee(iter(iterable)) 
  6.   next(offset) 
  7.   return zip(it, offset) 
  8. l = [1, 2, 3, 4, 5, 6] 
  9. dd = window2(l) 
  10. for a in dd: 
  11.     print(a) 

運行結(jié)果如下: 

  1. (1, 2) 
  2. (2, 3) 
  3. (3, 4) 
  4. (4, 5) 
  5. (5, 6) 

5.Trick4

有時,我們會需要一個類來存儲信息,但是如果我們覺得創(chuàng)建一個類并定義其__init__()函數(shù)太麻煩時,我們不妨選擇使用dataclass。如下所示: 

  1. from dataclasses import dataclass 
  2. @dataclass 
  3. class Person: 
  4.   name: str 
  5.   age: int 
  6.   address: str 

上述代碼創(chuàng)建了一個具有默認構(gòu)造函數(shù)的類,該類以與聲明相同的順序接收相應字段的賦值。

  1. person = Person(name='John', age=12, address='nanjing street'

dataclass的另一個優(yōu)點是,默認情況下,會生成特殊方法,如__str__、 repr 、__eq__等。關(guān)于dataclass的更多用法,可以 參考官網(wǎng) 。

值得一提的是我們在類中聲明的成員變量的類型注釋(str、int等)并不強制在構(gòu)造函數(shù)中傳遞的值屬于這種類型。也就是說dataclasses構(gòu)造對象時并不執(zhí)行數(shù)據(jù)類型的檢查。

6.Trick5

我們有時希望將一個對象上的操作視為tuple上的操作,一種選擇是使用collections.namedtuple,但也存在更類似于dataclass的實現(xiàn)。如下: 

  1. from typing import NamedTuple  
  2. class Coordinate(NamedTuple):  
  3. x: int  
  4. y: int 

上述定義了一個標準的類可以被當做tuple來使用,如下: 

  1. coordinate = Coordinate(10, 15)  
  2. coordinate.x == coordinate[0] // True  
  3. coordinate.y == coordinate[1] // True 

7.Trick6

假如我們有一個dataclass,需要驗證輸入數(shù)據(jù)是否符合類型注釋。在這種情況下,安裝第三方軟件包pydantic并將

from dataclasses import dataclass 替換為 from pydantic.dataclasses import dataclass 即可,如下: 

  1. from pydantic.dataclasses import dataclass 
  2. @dataclass 
  3. class Person: 
  4.   name: str 
  5.   age: int 
  6.   address: str 

這將生成一個類,該類具有根據(jù)成員變量聲明的類型進行輸入數(shù)據(jù)的解析和類型驗證。 Pydantic 在運行時強制執(zhí)行類型提示,并在數(shù)據(jù)無效時提供友好的錯誤提醒。

8.Trick7

在某些情況下,我們需要生成一些容器中元素頻率的基本統(tǒng)計信息。在這種情況下,您可以使用標準結(jié)構(gòu)Counter來接收iterable并根據(jù)元素的頻率生成相應的統(tǒng)計信息。 

  1. from collections import Counter 
  2. l = [1, 1, 2, 3, 4, 4] 
  3. frequencys = Counter(l) 
  4. print(frequencys[1])    // Ouput: 2 
  5. print(frequencys[2])    // Ouput: 1 
  6. print(frequencys[2323]) // Ouput: 0 

Counter也提供了一些其他方法,比如如most_common,用于檢索最常見的元素。

9.Trick8

如果我們相對兩個list中的元素對做相應的函數(shù)處理,我們最容易想到的方法如下: 

  1. l1 = [1, 2, 3]  
  2. l2 = [4, 5, 6]  
  3. for (e1, e2) in zip(l1, l2):  
  4. f(e1, e2) 

但是使用函數(shù)map可以讓代碼更加簡潔一些。 

  1. l1 = [1, 2, 3]  
  2. l2 = [4, 5, 6]  
  3. map(f, l1, l2)  

10.Trick9

有時候我們需要從一個list中隨機選擇一個元素,此時我們使用random.choice.如下所示: 

  1. from random import choice  
  2. l = [1, 2, 3]  
  3. random = choice(l) 

如果我們需要隨機選擇多個元素呢?當然是使用random.choices. 

  1. from random import choices 
  2. l = [1, 2, 3, 4, 5] 
  3. random_elements = choices(l, k=3) 

上述代碼中的參數(shù)k為我們隨機選擇元素的個數(shù)。

11.總結(jié)

本文重點介紹了在python中9個和迭代相關(guān)的使用技巧,可以方便提升大家的工作效率。

您學廢了嗎?

 

責任編輯:未麗燕 來源: 今日頭條
相關(guān)推薦

2019-07-22 06:33:55

R語言編程函數(shù)

2021-05-07 22:11:56

寬帶手機運營商

2018-01-25 09:15:16

機房機柜走線

2021-01-12 12:33:20

Pandas技巧代碼

2023-12-21 14:40:09

Python編程語言

2025-02-04 17:33:00

2022-06-23 13:13:36

GitHub開發(fā)技巧

2023-05-22 15:37:31

CSS元素JavaScript

2023-08-14 15:56:52

CSS 偽元素開發(fā)

2019-12-17 15:10:21

Python字符串代碼

2020-01-29 19:40:36

Python美好,一直在身邊Line

2021-01-05 11:22:58

Python字符串代碼

2020-07-11 09:45:33

Python編程語言開發(fā)

2021-08-24 00:13:23

Windows 10Windows微軟

2020-07-14 08:43:54

VueHTML函數(shù)

2009-04-14 21:38:05

LinuxUbuntu技巧

2023-07-07 14:47:46

JavaScript技巧

2025-04-16 07:06:43

2020-06-09 07:42:30

重命名文件 Linux

2021-11-02 19:14:58

Spring數(shù)據(jù)
點贊
收藏

51CTO技術(shù)棧公眾號