欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

Python教程·迭代、可迭代對(duì)象、迭代器與生成器詳解

iteration(迭代)

迭代是Python最強(qiáng)大的功能之一,是訪問集合元素的一種方式。

公司主營業(yè)務(wù):網(wǎng)站制作、成都網(wǎng)站制作、移動(dòng)網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競(jìng)爭(zhēng)能力。創(chuàng)新互聯(lián)是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)推出慶安免費(fèi)做網(wǎng)站回饋大家。

只要是可迭代對(duì)象(Iterable),就可以通過for循環(huán)來遍歷,這種遍歷我們稱為迭代。

也就是說所有可作用于for循環(huán)的對(duì)象都是可迭代對(duì)象(Iterable)。

那么,如何判斷一個(gè)對(duì)象是可迭代對(duì)象呢?方法是通過collections模塊的Iterable類型判斷:

>>> from collections import Iterable
>>> isinstance(123,Iterable)            # Integer 不可迭代
False
>>> isinstance('abc',Iterable)          # String 可迭代
True
>>> isinstance([1,2,3],Iterable)        # List 可迭代
True
>>> isinstance(('a','b','c'),Iterable)  # Tuple 可迭代
True
>>> isinstance({'name':'Arno','Job':'Ops'},Iterable)    # Dictionary 可迭代
True

dict 迭代說明

默認(rèn)情況下,dict迭代的是key:

>>> d = {'Name':'Arno','Born':1993,'Job':'Ops'}
>>> for k in d:
...     print(k)
... 
Name
Born
Job

如果要迭代value,可以用for value in d.values():

>>> for v in d.values():
...     print(v)
... 
Arno
1993
Ops

如果要同時(shí)迭代key和value,可以用for k, v in d.items():

>>> for k,v in d.items():
...     print('key:', k, '\t', 'value:', v)
... 
key: Name    value: Arno
key: Born    value: 1993
key: Job     value: Ops

知識(shí)擴(kuò)展

在Python中,List元素是有索引的,那么如何實(shí)現(xiàn)類似Java那樣的下標(biāo)循環(huán)?

方法一,通過len()方法取得列表長(zhǎng)度,再結(jié)合range()方法實(shí)現(xiàn)索引下標(biāo)循環(huán):

>>> L = ['a','b','c']
>>> for i in range(len(L)):
...     print(i, L[i])
... 
0 a
1 b
2 c

方法二,Python內(nèi)置的enumerate函數(shù)可以把一個(gè)list變成 索引-元素 對(duì),這樣就可以在for循環(huán)中同時(shí)迭代索引和元素本身:

>>> for i,v in enumerate(L):
...     print(i, v)
... 
0 a
1 b
2 c

iterator(迭代器)

迭代器是一個(gè)可以記住遍歷的位置的對(duì)象。

  • 迭代器對(duì)象從集合的第一個(gè)元素開始訪問,直到所有的元素被訪問完結(jié)束;
  • 迭代器只能往前不會(huì)后退;

迭代器有兩個(gè)基本的方法:

  • iter()
  • next()

可以通過 collections 模塊的 Iterator 類型判斷一個(gè)對(duì)象是否是迭代器:

>>> from collections import Iterator
>>> isinstance([1,2,3], Iterator)
False
>>> isinstance({'Name':'Arno','Born':1993,'Job':'Ops'}, Iterator)
False
>>> isinstance('abc', Iterator)
False
>>> isinstance(iter([1,2,3]), Iterator)             # iter()創(chuàng)建迭代器對(duì)象
True
>>> isinstance((x for x in range(10)), Iterator)    # 生成器
True

可以看出,生成器(generator)都是迭代器(Iterator)對(duì)象,但String、List、Tuple、Dict雖然是可迭代對(duì)象(Iterable),卻不是迭代器(Iterator)。

當(dāng)然,String、List、Tuple、Dict等可迭代對(duì)象都可用于創(chuàng)建迭代器:

>>> L = [1,2,3]
>>> it = iter(L)
>>> print(next(it))
1
>>> print(next(it))
2
>>> print(next(it))
3
>>> print(next(it))     # 沒有值可返回時(shí),拋異常 StopIteration
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
StopIteration
>>> 

迭代器對(duì)象常使用for語句進(jìn)行遍歷:

>>> L = [1,2,3]
>>> it = iter(L)
>>> for x in it:
...     print(x, end=" ")
... 
1 2 3 

也可以使用 next() 函數(shù):

>>> import sys
>>> L = [1,2,3]
>>> it = iter(L)
>>> while True:
...     try:
...         print(next(it))
...     except StopIteration:
...         sys.exit()
... 
1
2
3

generator(生成器)

創(chuàng)建生成器的方法:

  • 使用了 yield 語句的函數(shù)
    Generator 是一個(gè)用于創(chuàng)建迭代器的簡(jiǎn)單而強(qiáng)大的工具。 它們的寫法類似標(biāo)準(zhǔn)的函數(shù),但當(dāng)它們要返回?cái)?shù)據(jù)時(shí)會(huì)使用 yield 語句。 每次對(duì)生成器調(diào)用 next() 時(shí),它會(huì)從上次離開位置恢復(fù)執(zhí)行(它會(huì)記住上次執(zhí)行語句時(shí)的所有數(shù)據(jù)值)。
  • 使用生成器表達(dá)式,就是把一個(gè) 列表生成式的[]改成()
    某些簡(jiǎn)單的生成器可以寫成簡(jiǎn)潔的表達(dá)式代碼,所用語法類似列表推導(dǎo)式,將外層為圓括號(hào)而非方括號(hào)。 這種表達(dá)式被設(shè)計(jì)用于生成器將立即被外層函數(shù)所使用的情況。 生成器表達(dá)式相比完整的生成器更緊湊但較不靈活,相比等效的列表推導(dǎo)式則更為節(jié)省內(nèi)存。

yield 函數(shù)生成器

在 Python 中,使用了 yield 的函數(shù)被稱為生成器

跟普通函數(shù)不同的是,生成器是一個(gè)返回迭代器的函數(shù),只能用于迭代操作,更簡(jiǎn)單點(diǎn)理解生成器就是一個(gè)迭代器。

在調(diào)用生成器運(yùn)行的過程中,每次遇到 yield 時(shí)函數(shù)會(huì)暫停并保存當(dāng)前所有的運(yùn)行信息,返回yield的值。并在下一次執(zhí)行 next()方法時(shí)從當(dāng)前位置繼續(xù)運(yùn)行。

實(shí)例,使用 yield 實(shí)現(xiàn)斐波那契數(shù)列:

import sys

def fibonacci(n): # 生成器函數(shù) - 斐波那契
    a, b, counter = 0, 1, 0
    while True:
        if (counter > n): 
            return
        yield a
        a, b = b, a + b
        counter += 1
f = fibonacci(10) # f 是一個(gè)迭代器,由生成器返回生成

while True:
    try:
        print (next(f), end=" ")
    except StopIteration:
        sys.exit()

列表生成式

列表生成式(List Comprehensions)也叫列表推導(dǎo)式,提供了一個(gè)更簡(jiǎn)單的創(chuàng)建列表的方法。

常見的用法:

  • 是把某種操作應(yīng)用于序列或可迭代對(duì)象的每個(gè)元素上,然后使用其結(jié)果來創(chuàng)建列表;
  • 或者通過滿足某些特定條件元素來創(chuàng)建子序列;

例如,創(chuàng)建一個(gè)平方列表,像這樣

>>> squares = []
>>> for x in range(10):
...     squares.append(x**2)
...
>>> squares
[0, 1, 4, 9, 16, 25, 36, 49, 64, 81]

可以改為

>>> list(map(lambda x: x**2, range(10)))
[0, 1, 4, 9, 16, 25, 36, 49, 64, 81]

等價(jià)于

# 列表推導(dǎo)式,更加簡(jiǎn)潔易讀
>>> [x**2 for x in range(10)]
[0, 1, 4, 9, 16, 25, 36, 49, 64, 81]

增加特定條件

>>> [x**2 for x in range(10) if x % 2 != 0]
[1, 9, 25, 49, 81]

創(chuàng)建為生成器

>>> (x**2 for x in range(10) if x % 2 != 0)
<generator object <genexpr> at 0x7f076f06e990>

知識(shí)擴(kuò)展

lambda 表達(dá)式

lambda 表達(dá)式(有時(shí)稱為 lambda 構(gòu)型)被用于創(chuàng)建匿名函數(shù)。

表達(dá)式 lambda parameters: expression 會(huì)產(chǎn)生一個(gè)函數(shù)對(duì)象 。 該未命名對(duì)象的行為類似于用以下方式定義的函數(shù):

def <lambda>(parameters):
    return expression

注意:通過 lambda 表達(dá)式創(chuàng)建的函數(shù)不能包含語句或標(biāo)注。

map() 高階函數(shù)

接收兩個(gè)參數(shù),一個(gè)是函數(shù),一個(gè)是可迭代對(duì)象(Iterable),map將傳入的函數(shù)依次作用到序列的每個(gè)元素,并把結(jié)果作為新的iterator(迭代器)返回。

總結(jié)

  • 迭代(iteration)是訪問集合元素的一種方式;
  • 迭代器(iterator)對(duì)象一定是可迭代對(duì)象,反之則不一定;
  • 可迭代對(duì)象(Iterable)不一定是迭代器;
    例如list、dict、str等集合數(shù)據(jù)類型是可迭代對(duì)象,但不是迭代器,但是它們可以通過iter()函數(shù)生成一個(gè)迭代器對(duì)象。
  • 生成器(generator)對(duì)象既是可迭代對(duì)象也是迭代器;

遍歷方式

  • 迭代器、生成器和可迭代對(duì)象都可以用for循環(huán)去迭代
  • 生成器和迭代器還可以被next()方函數(shù)調(diào)用并返回下一個(gè)值

網(wǎng)頁題目:Python教程·迭代、可迭代對(duì)象、迭代器與生成器詳解
當(dāng)前鏈接:http://www.chinadenli.net/article38/geiepp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站排名商城網(wǎng)站微信公眾號(hào)企業(yè)建站定制開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站建設(shè)